Python+Selenium UI自动化 - 调用JS代码

news/2024/7/19 15:20:50 标签: python, selenium, ui, 自动化, js

当webdriver遇到无法完成的操作时候,这个时候可以使用javascript来完成,webdriver提供了execute_script()接口来调用js代码。

执行js有两种场景:

1、在页面上直接执行js

2、在某个已经定位的元素上执行js

百度新闻网页举例(js代码与浏览器有兼容问题)

1、向下滚动,举例内容为百度新闻网页滚动

语法:document.documentElement.scrollTop=10000

①document.body:网页正文

②scrollTop=10000:滚动一万像素 浏览器滚动条下滑操作

python">import time
from selenium import webdriver

driver  = webdriver.Chrome()
driver.get('http://news.baidu.com/')#打开百度新闻页面
driver.maximize_window()

js_str2 = 'document.documentElement.scrollTop=10000'#document.body:网页正文 scrollTop=10000:滚动一万像素 浏览器滚动条下滑操作,js代码与浏览器有兼容问题
driver.execute_script(js_str2)

百度新闻为瀑布流页面,若是想一直滚动,则可写个for循环实现

python">import time
from selenium import webdriver

driver  = webdriver.Chrome()
driver.get('http://news.baidu.com/')#打开百度新闻页面
driver.maximize_window()

js_str2 = 'document.documentElement.scrollTop=10000'
for i in range(6):#6为滚动的次数
    time.sleep(2)
    driver.execute_script(js_str2)

2、上下滚动,举例内容为百度新闻网页滚动

python">import time
from selenium import webdriver

driver  = webdriver.Chrome()
driver.get('http://news.baidu.com/')#打开百度新闻页面
driver.maximize_window()

js_str3 = 'document.body.scrollTop=%d'
for i in range(10):
    time.sleep(2)
    if(i%2==0):
        driver.execute_script(js_str3%10000)#向上正数
    else:
        driver.execute_script(js_str3%-10000)#向下负数

3、给属性加边框,举例内容为给百度新闻搜索框加红色边框

语法:driver.execute_script("arguments[0].style.border='5px solid red'",input_element)

①arguments[0]:代表元素e style.border:设置边框样式

②5px solid red:五个像素的红色实线

③input_element:选中的元素

若想要修改更多属性,可参考转载文章:UI自动化(2)---CSS基础知识 - MaggieTang - 博客园

python">import time
from selenium import webdriver
from selenium.webdriver.common.by import By

driver  = webdriver.Chrome()
driver.get('http://news.baidu.com/')
driver.maximize_window()
time.sleep(3)

input_element = driver.find_element(By.CSS_SELECTOR,'span#s_ipt_wr input.word')#定位到百度新闻页面的输入框
driver.execute_script("arguments[0].style.border='5px solid red'",input_element)#arguments[0]:代表元素e style.border:设置边框样式,5px solid red 五个像素的红色实线

4、移除属性,举例内容为去除“百度一下”按钮的文案(常用场景为定位时间控件时,如控制仅能选择时,改成可以输入)

语法:driver.execute_script('arguments[0].removeAttribute("value"),remove_element)

①remove_element为需要被移除的元素定位值

②value为需要被去除的属性名

python">import time
from selenium import webdriver
from selenium.webdriver.common.by import By

driver  = webdriver.Chrome()
driver.get('http://news.baidu.com/')
driver.maximize_window()
time.sleep(3)

remove_element = driver.find_element(By.ID,'s_btn_wr')#定位到百度一下按钮
driver.execute_script('arguments[0].removeAttribute("value"),remove_element)#去除百度一下文案

 5、修改属性,举例为将“百度一下”文案改为“我是丸子”

语法:driver.execute_script('arguments[0].setAttribute("value","我是丸子")',update_element)

python">import time
from selenium import webdriver
from selenium.webdriver.common.by import By

driver  = webdriver.Chrome()
driver.get('http://news.baidu.com/')
driver.maximize_window()
time.sleep(3)

update_element = driver.find_element(By.ID,'s_btn_wr')#定位到百度一下按钮
driver.execute_script('arguments[0].setAttribute("value","我是丸子")',update_element)#将百度一下文案替换为我是丸子


http://www.niftyadmin.cn/n/1377538.html

相关文章

replace小坑位一个

首先IE8是支持replace的,网上搜了文摘我还以为是不支持。 在IE8下,时间不支持2018-05-15这种格式,但是支持2018/05/15这种格式。 所以用到 replace 为了避免这种不支持的格式,就转为时间戳进行日期的增减操作 某个场景&#xff0c…

Python+Selenium UI自动化 - cookie处理方法及适用场景

方法一:手动登录系统后,F12查看页面cookies的值,键值对的形式写入代码中 add_cookie方法,实际编写时,遇到某些参数无效的报错 可以直接把对应的键值对删除,举例仅写了一行数据,实际运行需要写完…

sqrt()的运用

题目:一个整数,它加上100后是一个完全平方数,再加上168又是一个完全平方数,请问该数是多少? 1.程序分析:在10万以内判断,先将该数加上100后再开方,再将该数加上268后再开方&#xff…

CFA报名付款方式及支付失败解决方法

参加CFA考试的考生都知道CFA报名分为三个阶段,每一阶段的报名费用各不相同,CFA报名的付款方式有哪些? CFA协会接受以下付款方式 1.Visa,万事达卡,美国运通,大来卡,JCB和Discover 2.个人支票,公…

vnstat 查看服务器带宽统计命令

vnStat是一个Linux下的网络流量监控软件,它记录指定网卡每日的传输流量日志. 它并非基于网络包的过滤,而是分析文件系统- /proc, 所以vnStat无需root的权限就可使用. ,它还自带了 vnstati 命令,通过它可以直接可以输出流量统计图. #先安装epel源 [rootvpn ~]# yum install epel…

Python安装常见问题(1):zipimport.ZipImportError: can't decompress data

在CentOS以及其他的Linux系统中遇到安装包安装错误的原因,大多数都是因为缺少依赖包导致的,所以对于错误:zipimport.ZipImportError: can’t decompress data,是因为缺少zlib 的相关工具包导致的,知道了问题所在&#…

Python+Selenium UI自动化 - Unittest基本使用语法、断言、执行顺序

一、Unittest语法规则及示例 1、用import语句引入unittest模块 2、让所有执行测试的类都继承于TestCase类,可以将TestCase看成是对特定类进行测试的方法的集合 3、setUp()方法中进行测试前的初始化工作,teardown()方法中执行测试后的清除工作,它们都是…

python3+requests:使用类封装接口测试脚本

转载请注明出处:https://www.cnblogs.com/shapeL/p/9045439.html 前言:接口测试用例较多,我们不可能每个用例都写一次requests,get或者requests,post等,所以对共用方法要进行封装处理 第一次修改:将get请求和post请求单…