直接使用js操作页面,能解决很多click()不失效的问题
页面滚动到底部,顶部
处理富文本,时间控件的输入
js定位元素,滚动
execute_script 执行js
return 可以返回js的返回结果
from time import sleep
from selenium_webui.selenium_js.base import Base
class TestJS(Base):
def test_js_scroll(self):
self.driver.get('https://www.baidu.com/')
self.driver.find_element_by_id('kw').send_keys('selenium测试')
# self.driver.find_element_by_id('su').click()
ele = self.driver.execute_script("return document.getElementById('su')") # 返回元素
ele.click()
sleep(3)
self.driver.execute_script('document.documentElement.scrollTop=10000')
sleep(3)
self.driver.find_element_by_xpath('//*[@id="page"]/div/a[10]').click()
sleep(3)
# 打印出js的详细信息
for code in [
'return document.title', 'return JSON.stringify(performance.timing)' # 当前页面的标题,当前页面的一些性能数据
]:
print(self.driver.execute_script(code))
js处理时间控件
大部分时间控件都是readonly属性
处理时间控件:
1,取消日期的readonly属性
2,给value赋值
js代码实现,再webdriver对js进行处理
def test_datetime(self):
self.driver.get('url')
self.driver.execute_script("a = document.getElementById('element');a.removeAttribute('readonly')")
获取元素,去除readonly属性
self.driver.execute_script("document.getElementById('element').value='2021-20-19")
执行js,给value赋值