selenium执行js脚本

直接使用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赋值
上一篇:JAVA Script教程


下一篇:Web服务API跨域的Cross-Origin Read Blocking (CORB) blocked cross-origin response报错两种解决方案