cancel
Showing results for 
Search instead for 
Did you mean: 
Reply
BLawless
Frequent Visitor

Run JavaScript Function vs Web Automation

Hello! I am trying to understand some of the deeper concepts behind Power Automate Desktop (PAD) when it comes to web automation actions. I see that PAD offers the ability to perform form and UI operations such as clicking on a button and populating a text field. But I also see an option to "Run JavaScript function on a webpage" which can allow you to perform the same actions, and possibly others that are beyond the limitations of the web automation actions.

For example, if I wanted to click on a button on a page, I could use the "Web Automation">"Web form filling">"Press button on web page" (optionally "Web Automation">"Click link on web page" if the button is implemented appropriately) OR I can perform "Web Automation">"Run JavaScript function on web page" with the following script:   

document.querySelector('[/*CSS SELECTOR HERE*/]').click()


Another example would be if I wanted to fill out a text field I could use "Web Automation">"Web form filling">"Populate text field on a web page" and select the appropriate element and supply the given text, OR I can perform "Web Automation">"Run JavaScript function on web page" with the following script:   

function ExecuteScript() { 
document.getElementById(/*ElementID Here*/).value = "Some Text I Want To Insert";
}

Note that for most applications I can perform the "Run JavaScript function on a web page" operation as a fully enclosed function (function name and everything) or a single line command.
My point of confusion sits with not understanding the reasons for opting for an automation action over running a JavaScript function. What details should I take into account when deciding between achieving an action through one operation over the other? Are there any performance benefits that should be accounted for when choosing which implementation to use?  Any information that would help expand on this narrow concept would be greatly appreciated. 

1 ACCEPTED SOLUTION

Accepted Solutions
yasunm02
Solution Sage
Solution Sage

Hi @BLawless 

IMHO this kind of confusion results from considering only the 'tech' aspect of the product, and not the broader marketing perspective (marketing not as advertisement only, but product concept, strategy, positioning, etc.), which I believe is the most important here.

As part of Power Platform, PAD is a low-code solution intended to provide RPA to citizen developers. This is the product concept and main target market. That's why graphic automation actions are the primary option to build flows, and not a code screen. But Microsoft noticed Power Platform could also be an useful tool to pro devs, and that's why options such as 'Run JavaScript function on a webpage' in PAD, or integration with Python and R in Power BI, for example, were included. By doing that, Microsoft broadens the product's market.

Those two publics - citizen developers and dev pros - 'coexist' in PAD, and you have functionalities for both of them. So if you're a dev pro and considers running a JS fuction more useful, go with it. Instead, if you're a citizen developer and don't know code, go with predefined actions..

View solution in original post

4 REPLIES 4
yasunm02
Solution Sage
Solution Sage

Hi @BLawless 

IMHO this kind of confusion results from considering only the 'tech' aspect of the product, and not the broader marketing perspective (marketing not as advertisement only, but product concept, strategy, positioning, etc.), which I believe is the most important here.

As part of Power Platform, PAD is a low-code solution intended to provide RPA to citizen developers. This is the product concept and main target market. That's why graphic automation actions are the primary option to build flows, and not a code screen. But Microsoft noticed Power Platform could also be an useful tool to pro devs, and that's why options such as 'Run JavaScript function on a webpage' in PAD, or integration with Python and R in Power BI, for example, were included. By doing that, Microsoft broadens the product's market.

Those two publics - citizen developers and dev pros - 'coexist' in PAD, and you have functionalities for both of them. So if you're a dev pro and considers running a JS fuction more useful, go with it. Instead, if you're a citizen developer and don't know code, go with predefined actions..

Following up here with some additional remarks and questions regarding @yasunm02's resourceful and thorough response (thank you for getting back to me so quickly BTW):


@yasunm02 wrote:

As part of Power Platform, PAD is a low-code solution intended to provide RPA to citizen developers. This is the product concept and main target market. That's why graphic automation actions are the primary option to build flows, and not a code screen. 


This is actually why (despite having programming experience in Java, C#, JavaScript, C++, Swift, etc.) I'm using Power Automate Desktop. It's a great tool to rapidly prototype automations which I can then use as a "skeleton"/outline for an equivalent automation in a full on IDE. It allows me to test a proof of concept without having to do a lot of heavy coding. 


@yasunm02 wrote:

IMHO this kind of confusion results from considering only the 'tech' aspect of the product, and not the broader marketing perspective (marketing not as advertisement only, but product concept, strategy, positioning, etc.), which I believe is the most important here.



There are some downsides to this though when we neglect the technical aspect, namely the performance hit from the UI elements during debug time and the responsiveness issues of the editor. This is potentially related to either a memory leak issue or, and I haven't confirmed this, maybe it's due to PAD being a browser-based editor with some form of web wrapper executable where your workflow is saved to a central server and not a local instance. That's what it seems to behave as from my experience, especially when I observe the flow downloading each time you wish to execute it (and UI click and drag operations lagging to a noticeable degree). 

This performance concern actually begs the question that I didn't place as much significance on in my initial inquiry.

While I marked your answer as "correct" because it technically is the right answer when trying to address when we should be favoring one operation over its analogous coding equivalent in PAD from a "best practices" standpoint, it would help me if you could perhaps expand on the performance difference between a PAD flow performing a single "Run JavaScript on web page" action containing several operations and PAD flow performing the equivalent operations using other actions.

For example, to clarify, if I wanted to:
1. Get a value from a web page
2. Click on a button using a CSS Selector
3. Insert text into a textbox, and then
4. Press another button in the web page

I could either run a single "Run JavaScript on web page" action with all of those actions encapsulated in a single JavaScript function code block, or I can run those as separate actions using the various actions in the Web Automation portion of the action library.

Which would have a better runtime performance?  (For the sake of this argument, on top of ignoring "ease of use" factors when it comes to non-coding actions, let's also ignore the debugging and variable assignment benefits that PAD provides in the flow and focus strictly on runtime performance as most of these items can be handled with JavaScript analogs for variable assignment and try-catch blocks). 

Hi @BLawless 

 

Well, that'a good question to which I don't have an instant answer. It's certainly worth a test using timers to find out if there's a difference and whether this is relevant, didn't find anyone who ran this kind of test in community threads. If there's difference and it's in seconds scale, PAD's 'Get current date and time' action could capture it. Otherwise code or Excel would easily help.
Secondary to your question, but it's worth of note that better (faster) runtime has a limit on automation works due to factors such as page/apps load times, which is sensitive to internet connections, hardware config etc. Many times I have to insert delays actions in my flows to avoid errors because actions take place before the field is there.
My two cents.

Thanks @yasunm02 for replying back and bringing up a great suggestion on how to benchmark this.

If I have time and energy I will devise a test that makes use of the "Get Current Time" action, loops of the analogous operations, and a bit of logging skills that I've been learning over these past couple of months. I hope to report back with some insightful results and detailed testing procedures for others to recreate for validation purposes.

Helpful resources

Announcements

Power Platform Connections - Episode 7 | March 30, 2023

Episode Seven of Power Platform Connections sees David Warner and Hugo Bernier talk to Dian Taylor, alongside the latest news, product reviews, and community blogs.     Use the hashtag #PowerPlatformConnects on social media for a chance to have your work featured on the show.  

Announcing | Super Users - 2023 Season 1

Super Users – 2023 Season 1    We are excited to kick off the Power Users Super User Program for 2023 - Season 1.  The Power Platform Super Users have done an amazing job in keeping the Power Platform communities helpful, accurate and responsive. We would like to send these amazing folks a big THANK YOU for their efforts.      Super User Season 1 | Contributions July 1, 2022 – December 31, 2022  Super User Season 2 | Contributions January 1, 2023 – June 30, 2023    Curious what a Super User is? Super Users are especially active community members who are eager to help others with their community questions. There are 2 Super User seasons in a year, and we monitor the community for new potential Super Users at the end of each season. Super Users are recognized in the community with both a rank name and icon next to their username, and a seasonal badge on their profile.  Power Apps  Power Automate  Power Virtual Agents  Power Pages  Pstork1*  Pstork1*  Pstork1*  OliverRodrigues  BCBuizer  Expiscornovus*  Expiscornovus*  ragavanrajan  AhmedSalih  grantjenkins  renatoromao    Mira_Ghaly*  Mira_Ghaly*      Sundeep_Malik*  Sundeep_Malik*      SudeepGhatakNZ*  SudeepGhatakNZ*      StretchFredrik*  StretchFredrik*      365-Assist*  365-Assist*      cha_cha  ekarim2020      timl  Hardesh15      iAm_ManCat  annajhaveri      SebS  Rhiassuring      LaurensM  abm      TheRobRush  Ankesh_49      WiZey  lbendlin      Nogueira1306  Kaif_Siddique      victorcp  RobElliott      dpoggemann  srduval      SBax  CFernandes      Roverandom  schwibach      Akser  CraigStewart      PowerRanger  MichaelAnnis      subsguts  David_MA      EricRegnier  edgonzales      zmansuri  GeorgiosG      ChrisPiasecki  ryule      AmDev  fchopo      phipps0218  tom_riha      theapurva  takolota     Akash17  momlo     BCLS776  Shuvam-rpa     rampprakash  ScottShearer     Rusk  ChristianAbata     cchannon  Koen5     a33ik  Heartholme     AaronKnox  okeks      Matren   David_MA     Alex_10        Jeff_Thorpe        poweractivate        Ramole        DianaBirkelbach        DavidZoon        AJ_Z        PriyankaGeethik        BrianS        StalinPonnusamy        HamidBee        CNT        Anonymous_Hippo        Anchov        KeithAtherton        alaabitar        Tolu_Victor        KRider        sperry1625        IPC_ahaas      zuurg    rubin_boer   cwebb365   Dorrinda   G1124   Gabibalaban   Manan-Malhotra   jcfDaniel   WarrenBelz   Waegemma   drrickryp   GuidoPreite    If an * is at the end of a user's name this means they are a Multi Super User, in more than one community. Please note this is not the final list, as we are pending a few acceptances.  Once they are received the list will be updated. 

Register now for the Business Applications Launch Event | Tuesday, April 4, 2023

Join us for an in-depth look into the latest updates across Microsoft Dynamics 365 and Microsoft Power Platform that are helping businesses overcome their biggest challenges today.   Find out about new features, capabilities, and best practices for connecting data to deliver exceptional customer experiences, collaborating, and creating using AI-powered capabilities, driving productivity with automation—and building towards future growth with today’s leading technology.   Microsoft leaders and experts will guide you through the full 2023 release wave 1 and how these advancements will help you: Expand visibility, reduce time, and enhance creativity in your departments and teams with unified, AI-powered capabilities.Empower your employees to focus on revenue-generating tasks while automating repetitive tasks.Connect people, data, and processes across your organization with modern collaboration tools.Innovate without limits using the latest in low-code development, including new GPT-powered capabilities.    Click Here to Register Today!    

Check out the new Power Platform Communities Front Door Experience!

We are excited to share the ‘Power Platform Communities Front Door’ experience with you!   Front Door brings together content from all the Power Platform communities into a single place for our community members, customers and low-code, no-code enthusiasts to learn, share and engage with peers, advocates, community program managers and our product team members. There are a host of features and new capabilities now available on Power Platform Communities Front Door to make content more discoverable for all power product community users which includes ForumsUser GroupsEventsCommunity highlightsCommunity by numbersLinks to all communities Users can see top discussions from across all the Power Platform communities and easily navigate to the latest or trending posts for further interaction. Additionally, they can filter to individual products as well.   Users can filter and browse the user group events from all power platform products with feature parity to existing community user group experience and added filtering capabilities.     Users can now explore user groups on the Power Platform Front Door landing page with capability to view all products in Power Platform.      Explore Power Platform Communities Front Door today. Visit Power Platform Community Front door to easily navigate to the different product communities, view a roll up of user groups, events and forums.

Microsoft Power Platform Conference | Registration Open | Oct. 3-5 2023

We are so excited to see you for the Microsoft Power Platform Conference in Las Vegas October 3-5 2023! But first, let's take a look back at some fun moments and the best community in tech from MPPC 2022 in Orlando, Florida.   Featuring guest speakers such as Charles Lamanna, Heather Cook, Julie Strauss, Nirav Shah, Ryan Cunningham, Sangya Singh, Stephen Siciliano, Hugo Bernier and many more.   Register today: https://www.powerplatformconf.com/   

Users online (4,448)