跳到主要内容

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)
备注

对话框会被自动关闭,除非你添加了 page.on("dialog") 监听器。当监听器存在时,必须调用 dialog.accept()dialog.dismiss() 来处理对话框——否则页面会冻结等待对话框,像点击这样的操作将永远不会完成。


方法

accept

v1.9 之前添加 dialog.accept

当对话框被接受时返回。

用法

dialog.accept()
dialog.accept(**kwargs)

参数

  • prompt_text str (可选)#

    在提示框中输入的文本。如果对话框的 type 不是 prompt,则不会产生任何效果。可选。

返回值


dismiss

v1.9 之前添加 dialog.dismiss

当对话框被关闭时返回。

用法

dialog.dismiss()

返回值


属性

default_value

v1.9 之前添加 dialog.default_value

如果对话框是 prompt,则返回默认的提示值。否则返回空字符串。

用法

dialog.default_value

返回值


message

v1.9 之前添加 dialog.message

对话框中显示的消息内容。

用法

dialog.message

返回值


page

新增于: v1.34 dialog.page

触发该对话框的页面(如果有)。

用法

dialog.page

返回值


type

v1.9 之前添加 dialog.type

返回对话框的类型,可以是 alertbeforeunloadconfirmprompt 之一。

用法

dialog.type

返回值