Как обрабатывать всплывающие окна в кукловоде
как обработать всплывающее окно и получить доступ к всплывающему окну для выполнения некоторых операций над ним.
const puppeteer = require('puppeteer');
async function run() {
const browser = await puppeteer.launch();
const page = await browser.newPage();
await page.goto('https://example.com');
await page.click(Launchpopup);
}
Ответы
Ответ 1
Начиная с версии 0.13.0, вы можете использовать следующий код:
... code to open popup...
const pages = await browser.pages(); // get all open pages by the browser
const popup = pages[pages.length - 1]; // the popup should be the last page opened
Ответ 2
Этот код Typescript, но вы получаете идею:
async function waitForPopupMatching(
browser: Puppeteer.Browser,
regex: RegExp,
openAction: () => Promise<void>,
timeout: number = 30000,
): Promise<Puppeteer.Page> {
const promise = new Bluebird<Puppeteer.Target>(resolve => {
const listener = async (target: Puppeteer.Target) => {
if (target.type() === 'page' && regex.test(target.url())) {
browser.removeListener('targetcreated', listener);
resolve(target);
}
};
browser.addListener('targetcreated', listener);
}).timeout(timeout);
await openAction(); // Typically a mouse click
const tgt = await promise;
return await tgt.page();
}
Ответ 3
Итак, что я делаю, так это захожу на Facebook на их домашней странице, затем перехожу на страницу, на которую я хочу перейти, где я нажимаю на нее, чтобы войти с помощью кнопки facebook. И тогда этот код ниже будет, когда всплывающее окно произойдет, нажмите на кнопку входа с Facebook.
await page.click('[service_name="facebook"]')
const newPagePromise = new Promise(x => browser.once('targetcreated', target => x(target.page())));
const popup = await newPagePromise;
await popup.waitForSelector('[name="__CONFIRM__"]')
const confirm = await popup.$('[name="__CONFIRM__"]')
await popup.click('[name="__CONFIRM__"]')
await page.waitFor(2000);
await page.goto('your login page'); $
Ответ 4
Вы должны проверить документацию для v0.12.0-alpha, она описывает, как взаимодействовать с диалогами.
const puppeteer = require('puppeteer');
puppeteer.launch().then(async browser => {
const page = await browser.newPage();
await page.goto('https://example.com');
page.on('dialog', async dialog => {
console.log(dialog.message());
await dialog.dismiss();
await browser.close();
});
page.evaluate(() => alert('1'));
});
Релевантно docs можно найти здесь.