Dialog
Dialog 对象会通过页面的 page.on("dialog") 事件分发。
Dialog
类的使用示例:
- 同步
- 异步
from playwright.sync_api import sync_playwright, Playwright
def handle_dialog(dialog):
print(dialog.message)
dialog.dismiss()
def run(playwright: Playwright):
chromium = playwright.chromium
browser = chromium.launch()
page = browser.new_page()
page.on("dialog", handle_dialog)
page.evaluate("alert('1')")
browser.close()
with sync_playwright() as playwright:
run(playwright)
import asyncio
from playwright.async_api import async_playwright, Playwright
async def handle_dialog(dialog):
print(dialog.message)
await dialog.dismiss()
async def run(playwright: Playwright):
chromium = playwright.chromium
browser = await chromium.launch()
page = await browser.new_page()
page.on("dialog", handle_dialog)
page.evaluate("alert('1')")
await browser.close()
async def main():
async with async_playwright() as playwright:
await run(playwright)
asyncio.run(main())
备注
对话框会被自动关闭,除非你添加了 page.on("dialog") 监听器。当监听器存在时,必须调用 dialog.accept() 或 dialog.dismiss() 来处理对话框——否则页面会冻结等待对话框,像点击这样的操作将永远不会完成。
方法
accept
v1.9 之前添加当对话框被接受时返回。
用法
dialog.accept()
dialog.accept(**kwargs)
参数
返回值
dismiss
v1.9 之前添加当对话框被关闭时返回。
用法
dialog.dismiss()
返回值
属性
default_value
v1.9 之前添加如果对话框是 prompt,则返回默认的提示值。否则返回空字符串。
用法
dialog.default_value
返回值
message
v1.9 之前添加对话框中显示的消息内容。
用法
dialog.message
返回值
page
新增于: v1.34触发该对话框的页面(如果有)。
用法
dialog.page
返回值
type
v1.9 之前添加返回对话框的类型,可以是 alert
、beforeunload
、confirm
或 prompt
之一。
用法
dialog.type
返回值