Puppeteer invalid selector










0















I'm trying to fill a form with Puppeteer on a webpage, the input has an id and I'm using it as a selector.



The ID is :



#loginPage:SiteTemplate:formulaire:login-field


When I get the selector from chrome it gives me that :



#loginPage3a SiteTemplate3a formulaire3a login-field


And wether I put the first or the second option in Puppeteer it spits me out this error :



Error: Evaluation failed: DOMException: Failed to execute 'querySelector' on 'Document': '#loginPage:SiteTemplate:formulaire:login-field' is not a valid selector.


Here is the code if needed :



(async () => 
const browser = await puppeteer.launch(headless: false);
const page = await browser.newPage();
await page.goto('XXX');
await page.click(GOTO_LOGIN_BUTTON_SELECTOR)
await page.waitForNavigation(waitUntil: 'load');
await page.waitFor(EMAIL_SELECTOR); // here
await page.focus(EMAIL_SELECTOR);
await page.keyboard.type(CREDS.email);
await page.focus(PASSWORD_SELECTOR);
await page.keyboard.type(CREDS.password);

await browser.close();
)();









share|improve this question




























    0















    I'm trying to fill a form with Puppeteer on a webpage, the input has an id and I'm using it as a selector.



    The ID is :



    #loginPage:SiteTemplate:formulaire:login-field


    When I get the selector from chrome it gives me that :



    #loginPage3a SiteTemplate3a formulaire3a login-field


    And wether I put the first or the second option in Puppeteer it spits me out this error :



    Error: Evaluation failed: DOMException: Failed to execute 'querySelector' on 'Document': '#loginPage:SiteTemplate:formulaire:login-field' is not a valid selector.


    Here is the code if needed :



    (async () => 
    const browser = await puppeteer.launch(headless: false);
    const page = await browser.newPage();
    await page.goto('XXX');
    await page.click(GOTO_LOGIN_BUTTON_SELECTOR)
    await page.waitForNavigation(waitUntil: 'load');
    await page.waitFor(EMAIL_SELECTOR); // here
    await page.focus(EMAIL_SELECTOR);
    await page.keyboard.type(CREDS.email);
    await page.focus(PASSWORD_SELECTOR);
    await page.keyboard.type(CREDS.password);

    await browser.close();
    )();









    share|improve this question


























      0












      0








      0








      I'm trying to fill a form with Puppeteer on a webpage, the input has an id and I'm using it as a selector.



      The ID is :



      #loginPage:SiteTemplate:formulaire:login-field


      When I get the selector from chrome it gives me that :



      #loginPage3a SiteTemplate3a formulaire3a login-field


      And wether I put the first or the second option in Puppeteer it spits me out this error :



      Error: Evaluation failed: DOMException: Failed to execute 'querySelector' on 'Document': '#loginPage:SiteTemplate:formulaire:login-field' is not a valid selector.


      Here is the code if needed :



      (async () => 
      const browser = await puppeteer.launch(headless: false);
      const page = await browser.newPage();
      await page.goto('XXX');
      await page.click(GOTO_LOGIN_BUTTON_SELECTOR)
      await page.waitForNavigation(waitUntil: 'load');
      await page.waitFor(EMAIL_SELECTOR); // here
      await page.focus(EMAIL_SELECTOR);
      await page.keyboard.type(CREDS.email);
      await page.focus(PASSWORD_SELECTOR);
      await page.keyboard.type(CREDS.password);

      await browser.close();
      )();









      share|improve this question
















      I'm trying to fill a form with Puppeteer on a webpage, the input has an id and I'm using it as a selector.



      The ID is :



      #loginPage:SiteTemplate:formulaire:login-field


      When I get the selector from chrome it gives me that :



      #loginPage3a SiteTemplate3a formulaire3a login-field


      And wether I put the first or the second option in Puppeteer it spits me out this error :



      Error: Evaluation failed: DOMException: Failed to execute 'querySelector' on 'Document': '#loginPage:SiteTemplate:formulaire:login-field' is not a valid selector.


      Here is the code if needed :



      (async () => 
      const browser = await puppeteer.launch(headless: false);
      const page = await browser.newPage();
      await page.goto('XXX');
      await page.click(GOTO_LOGIN_BUTTON_SELECTOR)
      await page.waitForNavigation(waitUntil: 'load');
      await page.waitFor(EMAIL_SELECTOR); // here
      await page.focus(EMAIL_SELECTOR);
      await page.keyboard.type(CREDS.email);
      await page.focus(PASSWORD_SELECTOR);
      await page.keyboard.type(CREDS.password);

      await browser.close();
      )();






      javascript css-selectors puppeteer headless-browser






      share|improve this question















      share|improve this question













      share|improve this question




      share|improve this question








      edited Nov 16 '18 at 14:24









      BoltClock

      522k12911611196




      522k12911611196










      asked Nov 14 '18 at 11:59









      SkïpSkïp

      2618




      2618






















          2 Answers
          2






          active

          oldest

          votes


















          1














          One option, for an ID like that, is to do as follows:



          const EMAIL_SELECTOR = '[id="loginPage:SiteTemplate:formulaire:login-field"]';


          Or, if that doesn't work, split it up as follows to work around the use of the ::



          const EMAIL_SELECTOR = '[id*="loginPage"][id*="SiteTemplate"][id*="formulaire"][id*="login-field"]';


          Hopefully one (or both) of those will help!






          share|improve this answer






























            0














            I'm not sure but I would drop the line await page.waitForNavigation(waitUntil: 'load');



            And replace await page.waitFor(EMAIL_SELECTOR); // here



            with await page.waitForSelector(EMAIL_SELECTOR);



            And test to see if just using #login-field or other #loginPage > SiteTemplate > formulaire > login-field



            I could be wrong as I'm still working this out too.






            share|improve this answer






















              Your Answer






              StackExchange.ifUsing("editor", function ()
              StackExchange.using("externalEditor", function ()
              StackExchange.using("snippets", function ()
              StackExchange.snippets.init();
              );
              );
              , "code-snippets");

              StackExchange.ready(function()
              var channelOptions =
              tags: "".split(" "),
              id: "1"
              ;
              initTagRenderer("".split(" "), "".split(" "), channelOptions);

              StackExchange.using("externalEditor", function()
              // Have to fire editor after snippets, if snippets enabled
              if (StackExchange.settings.snippets.snippetsEnabled)
              StackExchange.using("snippets", function()
              createEditor();
              );

              else
              createEditor();

              );

              function createEditor()
              StackExchange.prepareEditor(
              heartbeatType: 'answer',
              autoActivateHeartbeat: false,
              convertImagesToLinks: true,
              noModals: true,
              showLowRepImageUploadWarning: true,
              reputationToPostImages: 10,
              bindNavPrevention: true,
              postfix: "",
              imageUploader:
              brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
              contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
              allowUrls: true
              ,
              onDemand: true,
              discardSelector: ".discard-answer"
              ,immediatelyShowMarkdownHelp:true
              );



              );













              draft saved

              draft discarded


















              StackExchange.ready(
              function ()
              StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53299763%2fpuppeteer-invalid-selector%23new-answer', 'question_page');

              );

              Post as a guest















              Required, but never shown

























              2 Answers
              2






              active

              oldest

              votes








              2 Answers
              2






              active

              oldest

              votes









              active

              oldest

              votes






              active

              oldest

              votes









              1














              One option, for an ID like that, is to do as follows:



              const EMAIL_SELECTOR = '[id="loginPage:SiteTemplate:formulaire:login-field"]';


              Or, if that doesn't work, split it up as follows to work around the use of the ::



              const EMAIL_SELECTOR = '[id*="loginPage"][id*="SiteTemplate"][id*="formulaire"][id*="login-field"]';


              Hopefully one (or both) of those will help!






              share|improve this answer



























                1














                One option, for an ID like that, is to do as follows:



                const EMAIL_SELECTOR = '[id="loginPage:SiteTemplate:formulaire:login-field"]';


                Or, if that doesn't work, split it up as follows to work around the use of the ::



                const EMAIL_SELECTOR = '[id*="loginPage"][id*="SiteTemplate"][id*="formulaire"][id*="login-field"]';


                Hopefully one (or both) of those will help!






                share|improve this answer

























                  1












                  1








                  1







                  One option, for an ID like that, is to do as follows:



                  const EMAIL_SELECTOR = '[id="loginPage:SiteTemplate:formulaire:login-field"]';


                  Or, if that doesn't work, split it up as follows to work around the use of the ::



                  const EMAIL_SELECTOR = '[id*="loginPage"][id*="SiteTemplate"][id*="formulaire"][id*="login-field"]';


                  Hopefully one (or both) of those will help!






                  share|improve this answer













                  One option, for an ID like that, is to do as follows:



                  const EMAIL_SELECTOR = '[id="loginPage:SiteTemplate:formulaire:login-field"]';


                  Or, if that doesn't work, split it up as follows to work around the use of the ::



                  const EMAIL_SELECTOR = '[id*="loginPage"][id*="SiteTemplate"][id*="formulaire"][id*="login-field"]';


                  Hopefully one (or both) of those will help!







                  share|improve this answer












                  share|improve this answer



                  share|improve this answer










                  answered Nov 14 '18 at 14:57









                  AJC24AJC24

                  1,1932716




                  1,1932716























                      0














                      I'm not sure but I would drop the line await page.waitForNavigation(waitUntil: 'load');



                      And replace await page.waitFor(EMAIL_SELECTOR); // here



                      with await page.waitForSelector(EMAIL_SELECTOR);



                      And test to see if just using #login-field or other #loginPage > SiteTemplate > formulaire > login-field



                      I could be wrong as I'm still working this out too.






                      share|improve this answer



























                        0














                        I'm not sure but I would drop the line await page.waitForNavigation(waitUntil: 'load');



                        And replace await page.waitFor(EMAIL_SELECTOR); // here



                        with await page.waitForSelector(EMAIL_SELECTOR);



                        And test to see if just using #login-field or other #loginPage > SiteTemplate > formulaire > login-field



                        I could be wrong as I'm still working this out too.






                        share|improve this answer

























                          0












                          0








                          0







                          I'm not sure but I would drop the line await page.waitForNavigation(waitUntil: 'load');



                          And replace await page.waitFor(EMAIL_SELECTOR); // here



                          with await page.waitForSelector(EMAIL_SELECTOR);



                          And test to see if just using #login-field or other #loginPage > SiteTemplate > formulaire > login-field



                          I could be wrong as I'm still working this out too.






                          share|improve this answer













                          I'm not sure but I would drop the line await page.waitForNavigation(waitUntil: 'load');



                          And replace await page.waitFor(EMAIL_SELECTOR); // here



                          with await page.waitForSelector(EMAIL_SELECTOR);



                          And test to see if just using #login-field or other #loginPage > SiteTemplate > formulaire > login-field



                          I could be wrong as I'm still working this out too.







                          share|improve this answer












                          share|improve this answer



                          share|improve this answer










                          answered Nov 15 '18 at 9:08









                          HellonearthisHellonearthis

                          6851718




                          6851718



























                              draft saved

                              draft discarded
















































                              Thanks for contributing an answer to Stack Overflow!


                              • Please be sure to answer the question. Provide details and share your research!

                              But avoid


                              • Asking for help, clarification, or responding to other answers.

                              • Making statements based on opinion; back them up with references or personal experience.

                              To learn more, see our tips on writing great answers.




                              draft saved


                              draft discarded














                              StackExchange.ready(
                              function ()
                              StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53299763%2fpuppeteer-invalid-selector%23new-answer', 'question_page');

                              );

                              Post as a guest















                              Required, but never shown





















































                              Required, but never shown














                              Required, but never shown












                              Required, but never shown







                              Required, but never shown

































                              Required, but never shown














                              Required, but never shown












                              Required, but never shown







                              Required, but never shown







                              這個網誌中的熱門文章

                              Barbados

                              How to read a connectionString WITH PROVIDER in .NET Core?

                              Node.js Script on GitHub Pages or Amazon S3