Как заполнить поле ввода с помощью кукловода

Я использую кукловода для теста E2E и сейчас пытаюсь заполнить поле ввода с кодом ниже.

await page.type('#email', '[email protected]');

Это сработало, но я обнаружил, что адрес электронной почты был введен в поле один за другим, как будто печатал настоящий человек.
Можно ли разрешить заполнять поле ввода адресом электронной почты за раз?

Ответ 1

Просто установите значение ввода следующим образом:

await page.$eval('#email', el => el.value = '[email protected]');

Вот пример его использования в Википедии:

const puppeteer = require('puppeteer');

(async () => {
    const browser = await puppeteer.launch();
    const page = await browser.newPage();
    await page.goto('https://en.wikipedia.org', {waitUntil: 'networkidle2'});

    await page.waitFor('input[name=search]');

    // await page.type('input[name=search]', 'Adenosine triphosphate');
    await page.$eval('input[name=search]', el => el.value = 'Adenosine triphosphate');

    await page.click('input[type="submit"]');
    await page.waitForSelector('#mw-content-text');
    const text = await page.evaluate(() => {
        const anchor = document.querySelector('#mw-content-text');
        return anchor.textContent;
    });
    console.log(text);
    await browser.close();
})();

Ответ 2

Чтобы расширить принятый ответ выше, вы можете использовать $ eval с переменными локального диапазона,

const myLocalValue = 'Adenosine triphosphate';    
await page.$eval('input[name=search]', (el, value) => el.value = value, myLocalValue);

Это займет "myLocalValue" из локальной области и передаст его в область браузера как "значение",

Ответ 3

другой способ сделать

await page.focus('#email')
await page.keyboard.type('test54')