javascript - Puppeteer:如何提交表单?

标签 javascript node.js google-chrome-headless puppeteer

使用 puppeteer ,您如何以编程方式提交表单?到目前为止,如果表单实际上包含提交输入,我已经能够使用 page.click('.input[type="submit"]') 来做到这一点。但是对于不包含提交输入的表单,专注于表单文本输入元素并使用 page.press('Enter') 似乎并没有真正导致表单提交:

const puppeteer = require('puppeteer');

(async() => {

    const browser = await puppeteer.launch();
    const page = await browser.newPage();
    await page.goto('https://stackoverflow.com/', {waitUntil: 'load'});
    console.log(page.url());

    // Type our query into the search bar
    await page.focus('.js-search-field');
    await page.type('puppeteer');

    // Submit form
    await page.press('Enter');

    // Wait for search results page to load
    await page.waitForNavigation({waitUntil: 'load'});


    console.log('FOUND!', page.url());

    // Extract the results from the page
    const links = await page.evaluate(() => {
      const anchors = Array.from(document.querySelectorAll('.result-link a'));
      return anchors.map(anchor => anchor.textContent);
    });
    console.log(links.join('\n'));
    browser.close();

})();

最佳答案

如果您尝试填写并提交登录表单,您可以使用以下方法:

await page.goto('https://www.example.com/login');

await page.type('#username', 'username');
await page.type('#password', 'password');

await page.click('#submit');

await page.waitForNavigation();

console.log('New Page URL:', page.url());

关于javascript - Puppeteer:如何提交表单?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45778181/

相关文章:

javascript - Angular UI 路由器子状态不适用于 IE

javascript - 在没有fs的情况下读取txt文件nodejs(来自url)

javascript - 带有三元运算符的 ES6 .some() 表现不同

google-chrome - 在 headless 模式下运行 Chrome

node.js - 为什么 puppeteer 报告 "UnhandledPromiseRejectionWarning: Error: Navigation failed because browser has disconnected!"?

javascript - 自己的定时器组件与 react ,回流不工作

javascript - ASP.Net 导航选项卡,如 Windows 选项卡控件

java - 通过 Linux 以 headless 模式运行 Selenium 会导致错误

javascript - 如果之前 DOM 元素中的部分旧内容达到了特定高度,则创建新的 DOM 元素

mysql - 在 MySQL 和 Nodejs 上更新单行中的整个或部分列