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'])
相关推荐
ssshooter4 小时前
看完就懂 useSyncExternalStore
前端·javascript·react.js
孟健4 小时前
Karpathy 用 200 行纯 Python 从零实现 GPT:代码逐行解析
python
Live000005 小时前
在鸿蒙中使用 Repeat 渲染嵌套列表,修改内层列表的一个元素,页面不会更新
前端·javascript·react native
柳杉5 小时前
使用Ai从零开发智慧水利态势感知大屏(开源)
前端·javascript·数据可视化
球球pick小樱花6 小时前
游戏官网前端工具库:海内外案例解析
前端·javascript·css
喝水的长颈鹿6 小时前
【大白话前端 02】网页从解析到绘制的全流程
前端·javascript
用户14536981458786 小时前
VersionCheck.js - 让前端版本更新变得简单优雅
前端·javascript
codingWhat6 小时前
整理「祖传」代码,就是在开发脚手架?
前端·javascript·node.js
码路飞6 小时前
写了个 AI 聊天页面,被 5 种流式格式折腾了一整天 😭
javascript·python
Lee川6 小时前
优雅进化的JavaScript:从ES6+新特性看现代前端开发范式
javascript·面试