首页 >> js开发 >> jsSelenium执行Javascript脚本参数及返回值过程详解js大全
jsSelenium执行Javascript脚本参数及返回值过程详解js大全
发布时间: 2021年1月13日 | 浏览:
| 分类:js开发
在Selenium中可以使用drvier.execute_script()来执行Javascript脚本,支持多行语句。
使用Javascript可以实现以下功能:
移除元素隐藏、禁用、只读等限制属性
为元素添加id或高亮样式
页面滚动
富文本框输入(HTML注入)
获取页面信息
移除元素隐藏、禁用、只读等限制属性为元素添加id或高亮样式页面滚动富文本框输入(HTML注入)获取页面信息
使用Javascript参数使用Javascript参数在使用Javascript语句时,还可以动态传入参数或元素对象,Javascript语句中使用占位符“argument[n]”来表示取第几个参数,如:
js = "arguments[0].setAttribute('style', arguments[1]);"
js = "arguments[0].setAttribute('style', arguments[1]);"这里埋设了两个参数,一个是元素对象,另一个是样式字符串。
element = driver.find_element_by_id("kw")
style = "background: red; border: 2px solid yellow;"
element = driver.find_element_by_id("kw")
style = "background: red; border: 2px solid yellow;"
执行脚本时,按顺序携带参数即可:driver.execute_script(js, element, style)
driver.execute_script(js, element, style)获取Javascript返回值
获取Javascript返回值在Javascript语句中加上return字样,如获取页面高度:js = 'return document.documentElement.scrollHeight;'
js = 'return document.documentElement.scrollHeight;'执行该后便可以拿到其返回值:
page_height = driver.execute_script(js)
page_height = driver.execute_script(js)完整示例
完整示例
import time
from selenium import webdriver
driver = webdriver.Chrome()
driver.get('https://www.baidu.com/')
js = 'arguments[0].setAttribute("style", arguments[1]);'
element = driver.find_element('id', 'kw')
style = 'background: red; border: 2px solid yellow;'
driver.execute_script(js, element, style)
page_height = driver.execute_script('return document.documentElement.scrollHeight;')
print(page_height)
time.sleep(3)
import time
from selenium import webdriver
driver = webdriver.Chrome()
driver.get('https://www.baidu.com/')
js = 'arguments[0].setAttribute("style", arguments[1]);'
element = driver.find_element('id', 'kw')
style = 'background: red; border: 2px solid yellow;'
driver.execute_script(js, element, style)
page_height = driver.execute_script('return document.documentElement.scrollHeight;')
print(page_height)
time.sleep(3)运行结果如图:
打印结果:890以上就是本文的全部内容,希望对大家的学习有所帮助。
使用Javascript可以实现以下功能:
移除元素隐藏、禁用、只读等限制属性
为元素添加id或高亮样式
页面滚动
富文本框输入(HTML注入)
获取页面信息
移除元素隐藏、禁用、只读等限制属性为元素添加id或高亮样式页面滚动富文本框输入(HTML注入)获取页面信息
使用Javascript参数使用Javascript参数在使用Javascript语句时,还可以动态传入参数或元素对象,Javascript语句中使用占位符“argument[n]”来表示取第几个参数,如:
js = "arguments[0].setAttribute('style', arguments[1]);"
js = "arguments[0].setAttribute('style', arguments[1]);"这里埋设了两个参数,一个是元素对象,另一个是样式字符串。
element = driver.find_element_by_id("kw")
style = "background: red; border: 2px solid yellow;"
element = driver.find_element_by_id("kw")
style = "background: red; border: 2px solid yellow;"
执行脚本时,按顺序携带参数即可:driver.execute_script(js, element, style)
driver.execute_script(js, element, style)获取Javascript返回值
获取Javascript返回值在Javascript语句中加上return字样,如获取页面高度:js = 'return document.documentElement.scrollHeight;'
js = 'return document.documentElement.scrollHeight;'执行该后便可以拿到其返回值:
page_height = driver.execute_script(js)
page_height = driver.execute_script(js)完整示例
完整示例
import time
from selenium import webdriver
driver = webdriver.Chrome()
driver.get('https://www.baidu.com/')
js = 'arguments[0].setAttribute("style", arguments[1]);'
element = driver.find_element('id', 'kw')
style = 'background: red; border: 2px solid yellow;'
driver.execute_script(js, element, style)
page_height = driver.execute_script('return document.documentElement.scrollHeight;')
print(page_height)
time.sleep(3)
import time
from selenium import webdriver
driver = webdriver.Chrome()
driver.get('https://www.baidu.com/')
js = 'arguments[0].setAttribute("style", arguments[1]);'
element = driver.find_element('id', 'kw')
style = 'background: red; border: 2px solid yellow;'
driver.execute_script(js, element, style)
page_height = driver.execute_script('return document.documentElement.scrollHeight;')
print(page_height)
time.sleep(3)运行结果如图:
打印结果:890以上就是本文的全部内容,希望对大家的学习有所帮助。
相关文章:
- js代码JavaScript undefined及null区别实例解析
- jsjQuery 添加元素和删除元素的方法js大全
- js在Echarts图中给坐标轴加一个标识线markLinejs大全
- js使用 Github Actions 自动部署 Angular 应用到 Github Pages的方法js大全
- jsmpvue 项目初始化及实现授权登录的实现方法js大全
- js一文读懂vue动态属性数据绑定(v-bind指令)js大全
- jsVue清除定时器setInterval优化方案分享js大全
- js解决elementUI 切换tab后 el_table 固定列下方多了一条线问题js大全
- js如何实现echarts markline标签名显示自己想要的js大全
- js详细分析vue表单数据的绑定js大全