对于前端隐藏元素,一直是selenium自动化定位元素的隐形杀手,脚本跑到隐藏元素时位置时报各种各样的错误,

隐藏的下拉菜单又没有办法避免,此帖只为交流隐藏元素自动化定位处理方法(3种操作)
       处理1:(修改样式)

html这种格式的:
           

处理操作:

 from selenium import webdriver
 from selenium.webdriver.support.select import Select
 import os,time

 driver = webdriver.Firefox()
 file_path = 'file:///' + os.path.abspath('test.html')
 driver.get(file_path)

 js = 'document.querySelectorAll("select")[0].style.display="block";'
 driver.execute_script(js)

 sel = driver.find_element_by_tag_name('select')
 Select(sel).select_by_value('opel')

 time.sleep(2)

 driver.quit()

来自虫师的解释:

document.querySelectorAll("select")[0].style.display="block";
document.querySelectorAll("select")  选择所有的select。
 [0] 指定这一组标签里的第几个。
style.display="block";  修改样式的display="block" ,表示可见。
 执行完这句js代码后,就可以正常操作下拉框了。
     
      处理2:(定位元素,修改样式)重点描述:
      调用js方法:execute_script(script, *args)
      在当前窗口/框架 同步执行JavaScript
      脚本:JavaScript的执行。
      *参数:适用任何JavaScript脚本。
      使用:driver.execute_script(‘document.title’)
     示例csdn登录框:

 #coding=utf-8
 from selenium import webdriver
 from time import sleep 

 driver = webdriver.Firefox()
 driver.get("http://www.csdn.net/")
 sleep(10)
 driver.find_element_by_link_text("登录").click()
 sleep(10) 

 #给用户名输入框标红显示
 js="var q=document.getElementById(\"username\");q.style.border=\"1px solid red\";"
 #调用js
 driver.execute_script(js)
 sleep(3) 

 driver.find_element_by_id("username").send_keys("username")
 driver.find_element_by_id("password").send_keys("password")
 driver.find_element_by_class_name("logging").click()
 sleep(3) 

 driver.quit()

JS调用解释:
        q=document.getElementById(\"username\")
         元素q的id 为username
         q.style.border=\"1px solid red\
         元素q的样式,边框为1个像素红色/
 3、隐藏元素:
   js.html

 <html>
     <head>
       <meta http-equiv="content-type" content="text/html;charset=utf-8" />
       <title>js</title>
       <script type="text/javascript" async="" src="http://ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js"></script>
       <link href="http://netdna.bootstrapcdn.com/twitter-bootstrap/2.3.2/css/bootstrap-combined.min.css" rel="stylesheet" />
       <script type="text/javascript">
         $(document).ready(function(){
           $('#tooltip').tooltip({"placement": "right"});
         });
       </script>
     </head>  

     <body>
       <h3>js</h3>
       <div class="row-fluid">
         <div class="span6 well">
           <a id="tooltip" href="#" data-toggle="tooltip" title=" selenium-webdriver(python)">hover to see tooltip</a>
           <a class="btn">Button</a>
         </div>
       </div>
     </body>
     <script src="http://netdna.bootstrapcdn.com/twitter-bootstrap/2.3.2/js/bootstrap.min.js"></script>
   </html>

python脚本:

 #coding=utf-8
 from selenium import webdriver
 import time,os 

 driver = webdriver.Firefox()
 file_path = 'file:///' + os.path.abspath('js.html')
 driver.get(file_path)
 '''
 通过JS 隐藏选中的元素
 '''
 #第一种方法:
 driver.execute_script('$("#tooltip").fadeOut();')
 time.sleep(5) 

 #第二种方法:
 button = driver.find_element_by_class_name('btn')
 driver.execute_script('$(arguments[0]).fadeOut()',button)
 time.sleep(5)

第一种是页面上引用;
    第二种是定位到元素后使用;
    具体解释如下:
         arguments对象,它是调用对象的一个特殊属性,用来引用Arguments对象。
         Arugments对象就像数组。
         fadeOut() 方法使选中元素隐藏起来,假如该元素是可隐藏的。
         fadein()则是相反渐显得意思。
    示例场景如下:

效果展示如下:

---------------------
作者:DCclient
来源:CSDN
原文:https://blog.csdn.net/DCclient/article/details/72900261
版权声明:本文为博主原创文章,转载请附上博文链接!

js操作:selenium无法操作隐藏元素问题的更多相关文章

  1. selenium+python自动化104-如何获取隐藏元素text文本

    前言 首先 selenium 是可以定位到隐藏元素的,但是 selenium 不能跟隐藏元素交互,也就是隐藏元素element不能使用element.click()方法. 隐藏元素element.te ...

  2. selenium如何高亮某元素和操作隐藏的内容

    高亮元素的思路是: 1.找到要高亮的元素 2.对该元素执行js,更改style达到高亮效果. 操作隐藏的内容思路: 1.可以用Actions的moveToElement,使鼠标悬停在触发隐藏内容的元素 ...

  3. Python+selenium(操作隐藏元素)

    测试过程中,偶尔会碰到一些页面的隐藏元素,如下,是小编举的一个简单的例子: test.html <html> <head></head> <body> ...

  4. selenium在操作隐藏元素时会报错,怎么判断元素是隐藏的?

    首先页面元素隐藏有五种方法: 1. opacity: 0; opacity 属性的意思是设置一个元素的透明度.它不是为改变元素的边界框(bounding box)而设计的.这意味着将 opacity ...

  5. Java&Selenium调用JS实现高亮被操作页面元素高亮

    Java&Selenium调用JS实现高亮被操作页面元素高亮 /* * the method of invoking js to do something * * @author daviey ...

  6. 如何借助浏览器Console使用Js进行定位和操作元素

    在进行Selenium自动化过程中,我们很难避免一些webdriver 很难定位到的一些元素(如:默认隐藏属性元素),那对于一些比较难定位到的元素,有什么好的解决办法?     其实我们都知道,Sel ...

  7. selenium之浏览器、元素、鼠标等操作总结

    1    控制浏览器 Selenium 主要提供的是操作页面上各种元素的方法,但它也提供了操作浏览器本身的方法,比如浏览器的大小以及浏览器后退.前进按钮等. 1.1  控制浏览器窗口大小 在不同的浏览 ...

  8. GSAP JS基础教程--TweenLite操作元素的相关属性

    今天来学习用TweenLite操作元素的各种属性,以Div为例,其他元素的操作也是一样的,只是可能一些元素有它们的特殊属性,就可能不同罢了.   代码里用详细注释,我就不再重复啦,大家看代码就可以啦! ...

  9. ui自动化之selenium操作(五)简单元素操作--续

    1. 多窗口切换 有时候需要在多窗口切换,webdriver提供了switch_to_window()方法支持切换窗口: from selenium import webdriver import o ...

随机推荐

  1. 复杂度定义 The Definition of Complexity

    The upper bound   Big-O: Definition: f(n) is in O(g(n)) if there are constants c0 and N0 such that f ...

  2. 控制结构(3): 状态机(state machine)

    // 上一篇:卫语句(guard clause) // 下一篇:局部化(localization) 基于语言提供的基本控制结构,更好地组织和表达程序,需要良好的控制结构. 前情回顾 上次分析了guar ...

  3. python多线程和多进程

    1 概念梳理: 1.1 线程 1.1.1 什么是线程 线程是操作系统能够进行运算调度的最小单位.它被包含在进程之中,是进程中的实际运作单位.一条线程指的是进程中一个单一顺序的控制流,一个进程中可以并发 ...

  4. Linux后台执行的方法 - 关闭、退出不影响

    =============================================================================================nohup c ...

  5. 【nowcoder-2017校招真题】保留最大的数

    牛客在线编程-保留最大的数 题目描述 给定一个十进制的正整数number,选择从里面去掉一部分数字,希望保留下来的数字组成的正整数最大. 输入描述: 输入为两行内容,第一行是正整数number,1 ≤ ...

  6. CentOS配置history记录每个用户执行过的命令

    一个偶然的机会,看到了这个文档,先存下来,后续使用的话直接就加进去了 要记录登录者的用户名.IP.操作记录,在/etc/bashrc末尾加入几个环境变量,用于history命令显示用户ip等内容,完成 ...

  7. DaishaPocedureOfMine(代码)

    create procedure GetGoodsInfoByPageNumber ( @provideID int, @pageNumber int, @GoodsCountOfOnePage fl ...

  8. Numpy进阶操作

    目录 1. 如何获取满足条设定件的索引 2. 如何将数据导入和导出csv文件 3. 如何保存和加载numpy对象 4. 如何按列或行拼接numpy数组 5. 如何按列对numpy数组进行排序 6. 如 ...

  9. Ubuntu 开机自动挂载硬盘

    1.查看Linux硬盘信息: $ sudo fdisk -l 2.格式化硬盘(根据需要确定文件系统): sudo mkfs.xfs /dev/sdb 3.创建/data目录 sudo mkdir /d ...

  10. 第十五节:深入理解async和await的作用及各种适用场景和用法

    一. 同步VS异步 1.   同步 VS 异步 VS 多线程 同步方法:调用时需要等待返回结果,才可以继续往下执行业务 异步方法:调用时无须等待返回结果,可以继续往下执行业务 开启新线程:在主线程之外 ...