zoukankan      html  css  js  c++  java
  • selenium.webdriver 高亮显示当前操作的元素

    高亮显示当前webdriver正在操作的元素,可以使用js代码来完成,两种写法:

    driver.execute_script('arguments[0].style.border="2px solid red";', ele)

    driver.execute_script('arguments[0].setAttribute("style", "border: 2px solid red");', ele)

    ele是通过driver定位到的元素,传入这个元素,arguments[0]就接受第一个传参,即该元素

    至于高亮的样式都可以自己用css指定

    但是这样只能高亮显示,在同一页面操作多个元素时会导致一片都高亮显示,所以自己研究了下,将高亮显示和还原方法放到了类中,代码如下:

    from selenium import webdriver
    from time import sleep
    
    class HighLight:
        # 初始化需要传入操作的driver
        def __init__(self, dr):
            self.driver = dr
            self.border = None
            self.ele = None
    
        def highlight(self, ele):
            self.ele = ele
            # 记录元素修改前的border样式
            self.border = self.ele.value_of_css_property('border')
            # 修改border样式,高亮显示
            self.driver.execute_script('arguments[0].style.border="2px solid red";', self.ele)
    
        def reset(self):
            if self.border is None or self.ele is None:
                return
            # 将border样式还原
            self.driver.execute_script(f'arguments[0].style.border="{self.border}";', self.ele)
            self.ele = None
            self.border = None
    
    with webdriver.Chrome() as driver:
        hl = HighLight(driver)
        driver.get('https://www.sogou.com/')
        driver.maximize_window()
        driver.implicitly_wait(5)
    
        query = driver.find_element_by_id('query')
        hl.highlight(query)
        query.send_keys('123')
        hl.reset()
        sleep(1)
    
        submit = driver.find_element_by_id('stb')
        hl.highlight(submit)
        submit.click()
        hl.reset()
        sleep(3)
    
    
  • 相关阅读:
    在.NET中读取嵌入和使用资源文件的方法
    T-SQL with关键字 with as 递归循环表
    IIS 部署WCF时遇到这么个错:
    WCF引用 代码
    C#中Windows通用的回车转Tab方法
    HTTP 错误 500.21
    如果你想开发一个应用(1-14)
    如果你想开发一个应用(1-13)
    如果你想开发一个应用(1-12)
    如果你想开发一个应用(1-11)
  • 原文地址:https://www.cnblogs.com/milesma/p/12333841.html
Copyright © 2011-2022 走看看