E2Eテストに puppeteer を使用していますが、入力フィールドに以下のコードを入力しようとしています。
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();
})();
上記の受け入れられた答えを拡張するには、ローカルスコープの変数でも$ evalを使用できます。
const myLocalValue = 'Adenosine triphosphate';
await page.$eval('input[name=search]', (el, value) => el.value = value, myLocalValue);
これにより、ローカルスコープから「myLocalValue」が取得され、「value」としてブラウザスコープに渡されます。
別の方法を行う
await page.focus('#email')
await page.keyboard.type('test54')