[Web自动化] Selenium执行JavaScript语句

10.3 Selenium执行JavaScript语句

在 Selenium 中,你可以使用 execute_script()execute_async_script() 方法来执行 JavaScript 语句。

以下是一些实用的例子:

10.3.1 执行简单的 JavaScript 语句

python 复制代码
from selenium import webdriver
driver = webdriver.Chrome()
driver.get("http://example.com")
# 执行简单的 JavaScript 语句,比如打印一条消息到控制台
driver.execute_script("console.log('Hello, World!');")

10.3.2 处理需要JavaScript渲染的页面元素

有时,页面元素是通过JavaScript动态生成的,直接使用Selenium的find_element方法可能找不到。这时,可以使用上述的execute_script方法来访问这些元素。

python 复制代码
# 执行JavaScript代码
driver.execute_script("alert('Hello from JavaScript!');")
# 访问需要JavaScript渲染的页面元素
element = driver.execute_script("return document.getElementById('dynamic_element');")

10.3.3 通过 JavaScript 点击元素

python 复制代码
# 假设页面上有一个按钮
button = driver.find_element_by_id("myButton")
# 使用 JavaScript 来点击这个按钮
driver.execute_script("arguments[0].click();", button)

10.3.4 获取元素属性值

python 复制代码
element = driver.find_element_by_id("myElement")
# 使用 JavaScript 获取元素的 'class' 属性值
class_name = driver.execute_script("return arguments[0].className;", element)
print(class_name)

10.3.5 设置元素属性值

python 复制代码
element = driver.find_element_by_id("myElement")
# 使用 JavaScript 设置元素的 'style.display' 属性
driver.execute_script("arguments[0].style.display = 'none';", element)

10.3.6 滚动到页面底部

python 复制代码
# 使用 JavaScript 滚动到页面底部
driver.execute_script("window.scrollTo(0, document.body.scrollHeight);")

10.3.7 等待页面元素加载完成

python 复制代码
# 等待某个元素出现在页面上
element = driver.find_element_by_id("myElement")
script = """
return new Promise((resolve, reject) => {
    const observer = new MutationObserver((mutations, observer) => {
        if (document.contains(arguments[0])) {
            resolve();
        }
    });
    observer.observe(document.body, { childList: true, subtree: true });
});
"""
driver.execute_script(script, element)

10.3.8 执行异步 JavaScript 代码

python 复制代码
# 假设你需要执行异步的 JavaScript 代码,比如等待一个 AJAX 请求完成
script = """
return fetch('https://api.example.com/data')
    .then(response => response.json())
    .then(data => {
        return data; // 或者你想要操作的数据
    });
"""
result = driver.execute_async_script(script)
print(result)

10.3.9 通过 JavaScript 获取元素的内部文本

python 复制代码
element = driver.find_element_by_id("myElement")
# 使用 JavaScript 获取元素的内部文本
text = driver.execute_script("return arguments[0].textContent;", element)
print(text)

10.3.10 通过 JavaScript 操作浏览器窗口

python 复制代码
# 使用 JavaScript 关闭当前浏览器窗口
driver.execute_script("window.close();")

这些例子展示了如何使用 execute_script() 方法执行各种 JavaScript 操作。在某些情况下,你可能需要将找到的 WebElement 作为参数传递给 JavaScript 代码,arguments[0] 是一个特殊的变量,它在 JavaScript 代码中代表了传递给 execute_script() 的第一个参数。

相关推荐
加农炮手Jinx14 分钟前
Flutter for OpenHarmony: Flutter 三方库 icon_font_generator 自动化将 SVG 图标集转化为字体文件(鸿蒙矢量资源全自动管理)
运维·flutter·华为·自动化·harmonyos·devops
成为你的宁宁2 小时前
Jenkins 自动化部署前后端分离若依项目全攻略:涵盖环境配置、Maven/Node.js 工具安装、GitLab 项目协同,及前后端构建、服务器推送与代码更新验证全步骤
node.js·自动化·gitlab·jenkins·maven
nimadan123 小时前
**AI漫剧软件2025推荐,解锁高性价比创意制作新体验**
人工智能·python
万物得其道者成4 小时前
前端大整数精度丢失:一次踩坑后的实战解决方案(`json-bigint`)
前端·json
鹏北海4 小时前
移动端 H5 响应式字体适配方案完全指南
前端
姜太公钓鲸2335 小时前
ROM就是程序存储器,实际的存储介质是Flash闪存。上述描述中的程序存储器是什么意思?
开发语言·javascript·ecmascript
WoodyPhang6 小时前
转载:自动化挂机,轻松建设:“养老院”邦国推出智能Bot服务平台,专为邦国崛起玩家设计
自动化
yunhuibin6 小时前
GoogLeNet学习
人工智能·python·深度学习·神经网络·学习
柳杉6 小时前
使用AI从零打造炫酷医疗数据可视化大屏,源码免费拿!
前端·javascript·数据可视化
凌云拓界6 小时前
前端开发的“平衡木”:在取舍之间找到最优解
前端·性能优化·架构·前端框架·代码规范·设计规范