木偶找不到元素

时间:2020-03-15 12:23:20

标签: javascript node.js puppeteer

我正在尝试使用puppeteer登录url,但是找不到输入元素和Submit按钮,我相信这些元素都是由javascript动态生成的,即使我使用的是waitForSelector它不起作用,我想念什么?

这是我的代码:

const puppeteer = require('puppeteer');

(async () => {

    try {

        const browser = await puppeteer.launch({
            headless: false
        });

        const page = await browser.newPage();
        await page.goto('http://contatoplus.com/#!login', { waitUntil: 'networkidle0' });


            await page.waitForFunction("document.querySelector('#gwt-uid-3') && document.querySelector('#gwt-uid-3').clientHeight != 0");
            // or wait until "visibility" not hidden
            await page.waitForFunction("document.querySelector('#gwt-uid-3') && document.querySelector('#gwt-uid-3').style.visibility != 'hidden'");

            const btnNext = await page.$('#gwt-uid-3');
            await btnNext.keyboard.type('loginnn');


} catch (error) {
    console.log(error);
}

})();

我遵循以下步骤: https://stackoverflow.com/a/54103671/5309671

1 个答案:

答案 0 :(得分:1)

对我来说,脚本在page.goto()阶段超时。

  1. 尝试删除, { waitUntil: 'networkidle0' }选项,page.waitForFunction()就足够了。
  2. page.$()返回不具有elementHandle属性的keyboard。只需使用await btnNext.type('loginnn');

一个变体:

const puppeteer = require('puppeteer');

(async function main() {
  try {
    const browser = await puppeteer.launch({ headless: false });
    const [page] = await browser.pages();

    await page.goto('http://contatoplus.com/#!login');

    await page.waitForFunction(() => {
      const selectors = ['#gwt-uid-3', '#gwt-uid-5', 'div[role="button"]'];
      return selectors.every(selector => document.querySelector(selector)?.clientHeight > 0);
    });

    await page.type('#gwt-uid-3', 'login');
    await page.type('#gwt-uid-5', 'password');
    await page.click('div[role="button"]');
  } catch (err) {
    console.error(err);
  }
})();