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'])
相关推荐
Chandler_Song8 分钟前
Excel 转化成JSON
python·json
ikonan17 分钟前
译:Chrome DevTools 实用技巧和窍门清单
前端·javascript
小高00724 分钟前
⚡️ Vue 3.5 正式发布:10× 响应式性能、SSR 水合黑科技、告别 .value!
前端·javascript·vue.js
葡萄城技术团队27 分钟前
【前沿解析】JavaScript 的未来,将迎来哪些新特性?
javascript
山烛28 分钟前
深度学习:CUDA、PyTorch下载安装
人工智能·pytorch·python·深度学习·cuda
撰卢1 小时前
总结一下vue3的组件之间数据转递,子组件传父组件,父组件传子组件
前端·javascript·vue.js
前端开发爱好者2 小时前
Vue3 超强“积木”组件!5 分钟搞定可交互 3D 机房蓝图!
前端·javascript·vue.js
前端开发爱好者2 小时前
尤雨溪力荐!Vue3 专属!100+ 动效组件!
前端·javascript·vue.js
前端开发爱好者2 小时前
尤雨溪力荐!Vue3 生态最强大的 14 个 UI 组件库!
前端·javascript·vue.js
lb29172 小时前
关于多个el-input的自动聚焦,每输入完一个el-input,自动聚焦到下一个
前端·javascript·vue.js