在 Playwright 中执行 JavaScript

Playwright 是一个强大的自动化测试库,支持在浏览器上下文中执行 JavaScript 脚本。

常见使用方法

通过使用 page.evaluate()locator.evaluate() 方法,可以在页面中执行各种 JavaScript 操作。

使用 page.evaluate() 方法

page.evaluate() 方法允许在页面上下文中执行 JavaScript 代码,并返回执行结果。它的基本语法如下:

result = await page.evaluate(script, *args)

其中,script 是一个 JavaScript 字符串,表示要在页面上下文中执行的代码,args 是可选参数,可以传递给 JavaScript 代码的参数列表。

示例代码

以下是一个使用 page.evaluate() 方法的示例,展示了如何在页面中执行 JavaScript 代码:

python 复制代码
from playwright.sync_api import sync_playwright

class TestJs:

def setup(self):

playwright = sync_playwright().start()

self.browser = playwright.chromium.launch(headless=False)

self.context = self.browser.new_context()

self.page = self.context.new_page()

def teardown(self):

self.browser.close()

def test_case1(self):

self.page.goto("https://www.baidu.com/")

# 获取浏览器语言

lan = self.page.evaluate("window.navigator.language;")

assert lan == "zh-CN"

# 获取当前浏览器标题

title = self.page.evaluate("document.title;")

assert title == self.page.title()

self.page.evaluate('document.getElementById("kw").value = "test"') # 搜索框输入"test"

text = self.page.evaluate("document.getElementById('kw').value") # 读取输入的值

assert text == "test"

self.page.evaluate('document.getElementById("su").click()') # 点击【百度一下】

self.page.click("#page >> text=2")

使用 locator.evaluate() 方法

locator.evaluate() 方法允许在定位到元素后执行 JavaScript 操作。以下是一个示例,展示了如何使用 locator.evaluate() 方法:

python 复制代码
def test\_case2(self):

self.page.goto("<https://www.baidu.com/>")

# 搜索框输入"test"

input\_handle = self.page.query\_selector("id=kw")

input\_handle.evaluate('node => node.value = "test"')

text = input\_handle.evaluate('node => node.value') # 读取输入的值

assert text == "test"

# 点击【百度一下】

submit\_handle = self.page.query\_selector("id=su")

submit\_handle.evaluate('node => node.click()')

time.sleep(10)

通过这些方法,您可以在 Playwright 中轻松地执行各种 JavaScript 操作,如操作 DOM 元素、获取页面数据、执行复杂的计算等,从而实现自动化测试和页面操作

相关推荐
五月君_6 小时前
炸裂!Claude Opus 4.6 与 GPT-5.3 同日发布:前端人的“自动驾驶“时刻到了?
前端·gpt
Mr Xu_6 小时前
前端开发中CSS代码的优化与复用:从公共样式提取到CSS变量的最佳实践
前端·css
鹏北海-RemHusband7 小时前
从零到一:基于 micro-app 的企业级微前端模板完整实现指南
前端·微服务·架构
LYFlied7 小时前
AI大时代下前端跨端解决方案的现状与演进路径
前端·人工智能
光影少年7 小时前
AI 前端 / 高级前端
前端·人工智能·状态模式
一位搞嵌入式的 genius7 小时前
深入 JavaScript 函数式编程:从基础到实战(含面试题解析)
前端·javascript·函数式
anOnion7 小时前
构建无障碍组件之Alert Dialog Pattern
前端·html·交互设计
choke2337 小时前
[特殊字符] Python 文件与路径操作
java·前端·javascript
云飞云共享云桌面7 小时前
高性能图形工作站的资源如何共享给10个SolidWorks研发设计用
linux·运维·服务器·前端·网络·数据库·人工智能
Deng9452013147 小时前
Vue + Flask 前后端分离项目实战:从零搭建一个完整博客系统
前端·vue.js·flask