对话框
简介
Playwright 可以与网页对话框进行交互,例如 alert、confirm、prompt 以及 beforeunload 确认。有关打印对话框,请参阅 打印。
alert()、confirm()、prompt() 对话框
默认情况下,Playwright 会自动关闭对话框,因此您无需手动处理。但是,您可以在触发对话框的操作之前注册一个对话框处理器,以调用 dialog.accept() 或 dialog.dismiss() 来处理它。
page.on('dialog', dialog => dialog.accept());
await page.getByRole('button').click();
注意
page.on('dialog') 监听器必须处理该对话框。否则,您的操作(无论是 locator.click() 还是其他操作)将会挂起。这是因为 Web 中的对话框是模态的,在被处理之前会阻塞页面的后续执行。
因此,以下代码片段将永远不会解决
警告
错误!
page.on('dialog', dialog => console.log(dialog.message()));
await page.getByRole('button').click(); // Will hang here
注意
如果没有为 page.on('dialog') 设置监听器,所有对话框都将被自动关闭。
beforeunload 对话框
当调用 page.close() 并传入为真的 runBeforeUnload 值时,页面会运行其卸载处理器。这是 page.close() 不会等待页面实际关闭的唯一情况,因为操作结束后页面可能会保持打开状态。
您可以注册一个对话框处理程序来自己处理 beforeunload 对话框
page.on('dialog', async dialog => {
assert(dialog.type() === 'beforeunload');
await dialog.dismiss();
});
await page.close({ runBeforeUnload: true });
打印对话框
为了断言通过 window.print 触发了打印对话框,您可以使用以下代码片段
await page.goto('<url>');
await page.evaluate('(() => {window.waitForPrintDialog = new Promise(f => window.print = f);})()');
await page.getByText('Print it!').click();
await page.waitForFunction('window.waitForPrintDialog');
这将等待在点击按钮后打开打印对话框。请确保在点击按钮之前/页面加载后评估脚本。