Web自动化之Selenium execute_script函数常用JS脚本

在Web自动化测试中,Selenium的execute_script函数是一个非常强大的工具,它允许我们直接在浏览器中执行JavaScript代码。使用时只需将JS代码按照字符串的格式传入即可。

常用JS代码

以下是一些常用的JavaScript代码示例,可以在Selenium的execute_script函数中直接使用:包括操作当前页面和操作某个元素。

操作当前页面

获取页面标题

python 复制代码
page_title=browser.execute_script('return document.title;')
print(page_title)

获取页面高度

python 复制代码
page_height = browser.execute_script("return document.documentElement.scrollHeight;")
print(page_height)

获取窗口大小

python 复制代码
window_size = browser.execute_script("return {width: window.innerWidth, height: window.innerHeight};")
print(window_size['width'], window_size['height'])

设置窗口大小

python 复制代码
browser.execute_script("window.resizeTo(800, 600);")

滚动到页面底部

python 复制代码
browser.execute_script("window.scrollTo(0, document.body.scrollHeight);")

刷新页面

python 复制代码
browser.execute_script("window.scrollTo(0, document.body.scrollHeight);")

获取页面当前url

python 复制代码
current_url = browser.execute_script("return window.location.href;")
print(current_url)

修改页面Url

python 复制代码
browser.execute_script("window.location.href = 'https://www.example.com';")

页面重定向

python 复制代码
browser.execute_script("window.location.replace('url');")

获取当前页面内所有herf链接

python 复制代码
js_script = """
var links = document.querySelectorAll('a');
var hrefs = [];
links.forEach(function(link) {
    var href = link.getAttribute('href');
    if (href) {
        hrefs.push(href);
    }
});
return hrefs;
"""

all_links = driver.execute_script(js_script)
# 打印所有获取到的链接
for link in all_links:
    print(link)

操作某个元素

点击元素

python 复制代码
element=browser.find_element(By.XPATH,'')
browser.execute_script('arguments[0].click()',element)

获取元素的文本

python 复制代码
element=browser.find_element(By.XPATH,'')
text=browser.execute_script('return arguments[0].textContent;',element)
print(text)

获取元素的属性值

python 复制代码
element=browser.find_element(By.XPATH,'')
attribute=browser.execute_script('return arguments[0].getAttribute('href');',element)
print(attribute)

滚动元素到视口

python 复制代码
element=browser.find_element(By.XPATH,'')
browser.execute_script(arguments[0].scrollIntoView({behavior: 'smooth', block: 'center'});",element)

检查元素是否可见

python 复制代码
element = browser.find_element(By.ID, 'dynamic-element')
is_visible = browser.execute_script("return arguments[0].offsetWidth > 0 && arguments[0].offsetHeight > 0;", element)
print(is_visible)

获取元素的尺寸

python 复制代码
size = browser.execute_script("return {width: arguments[0].offsetWidth, height: arguments[0].offsetHeight};", element)
print(size['width'], size['height'])
相关推荐
程序员爱钓鱼23 分钟前
Python编程实战 · 基础入门篇 | 第一个Python程序:Hello World
后端·python·编程语言
Allen_LVyingbo25 分钟前
2025年10月版集成RagFlow和Dify的医疗知识库自动化查询(安装篇)
运维·信息可视化·自动化·健康医疗
Rhys..40 分钟前
JS - npm init
开发语言·javascript·npm
newxtc1 小时前
【 广州产权交易所-注册安全分析报告-无验证方式导致安全隐患】
开发语言·人工智能·selenium·安全·yolo
川石课堂软件测试1 小时前
CSS中常用的几种定位。
开发语言·css·python·网络协议·http·html·pytest
C.R.xing1 小时前
Pyspark分布式访问NebulaGraph图数据库
数据库·分布式·python·pyspark·nebulagraph
我是华为OD~HR~栗栗呀1 小时前
华为OD-21届考研-Java面经
java·前端·c++·python·华为od·华为·面试
程序0071 小时前
HTML+JS+CSS实现汽车官网
javascript·css·html
没有鸡汤吃不下饭2 小时前
H5移动端页面实现快递单号条形码/二维码扫描,亲测可行!!
前端·javascript·vue.js
云枫晖2 小时前
JS核心知识-模块化
前端·javascript