专栏首页从零开始学自动化测试关于面试总结10-selenium中隐藏元素定位

关于面试总结10-selenium中隐藏元素定位

前言

面试题:selenium中隐藏元素如何定位?这个是很多面试官喜欢问的一个题,如果单纯的定位的话,隐藏元素和普通不隐藏元素定位没啥区别,用正常定位方法就行了 但是吧~~~很多面试官自己都搞不清楚啥叫定位,啥叫操作元素(如click,clear,send_keys)

隐藏元素

如下图有个输入框和一个登录的按钮,本来是显示的

元素的属性隐藏和显示,主要是 type="hidden"style="display: none;"属性来控制的,接下来在元素属性里面让它隐藏

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
<p>这里有个按钮,是隐藏的

<!-- type="hidden" -->
<br>
输入账号<input id="yoyo" name="hello" type="hidden">

<!-- type="display: none;" -->
<br>
<button id="yy" name="heo" style="display: none;">登录</button>
<br>

<a hidden id="baidu" href="https://www.baidu.com">访问百度</a>
</p>

</body>
</html>

这样元素就不会显示了,也就是面试官所说的隐藏属性了

定位隐藏元素

前面说了,定位隐藏元素和普通的元素没啥区别,接下来就来验证下,是不是能定位到呢?

from selenium import webdriver

driver = webdriver.Firefox()
driver.get("http://localhost:63342/test1122/a/b.html")

# 定位type="hidden"隐藏元素
ele1 = driver.find_element_by_id("yoyo")
print("打印元素信息:%s" % ele1)

# 获取元素属性
print(ele1.get_attribute("name"))

# 判断元素是否隐藏
print(ele1.is_displayed())

运行结果:

打印元素信息:<selenium.webdriver.remote.webelement.WebElement (session="1debdd46-21b1-451e-b8a7-5aeff1d74f9d", element="{28628a87-7f22-4574-9e14-931f9c6f20e1}")>
hello
False

运行结果可以看出,隐藏元素用普通定位方法,事实上是定位到了呢!

操作隐藏元素

隐藏元素可以正常定位到,只是不能操作(定位元素和操作元素是两码事,很多初学者傻傻分不清楚),操作元素是click,clear,send_keys这些方法

# 隐藏输入框元素输入文本
ele1 = driver.find_element_by_id("yoyo")
ele1.send_keys("yoyo")

隐藏元素用send_keys()方法会抛异常’ElementNotVisibleException’: Message: Element is not currently visible and so may not be interacted with 这个报错是说元素不可见,不可以被操作,同样的对“登录”按钮点击操作也是会报’ElementNotVisibleException’

# 点击隐藏登录框
ele2 = driver.find_element_by_id("yy")
ele2.click()

JS操作隐藏元素

如果面试官想问的是定位后操作隐藏元素的话,本质上说这个问题就是毫无意义的,web自动化的目的是模拟人的正常行为去操作。 如果一个元素页面上都看不到了,你人工也是无法操作的是不是?人工都不能操作,那你自动化的意义又在哪呢?所以这个只是为了单纯的考察面试者处理问题的能力,没啥实用性!(面试造飞机,进去拧螺丝) 既然面试官这么问了,那就想办法回答上给个好印象吧! 首先selenium是无法操作隐藏元素的(但是能正常定位到),本身这个框架就是设计如此,如果非要去操作隐藏元素,那就用js的方法去操作,selenium提供了一个入口可以执行js脚本。 js和selenium不同,只有页面上有的元素(在dom里面的),都能正常的操作,接下来用js试试吧!

<a hidden id="baidu" href="https://www.baidu.com">访问百度</a> 这个链接是隐藏的,但是能用js点到

from selenium import webdriver

driver = webdriver.Firefox()
driver.get("http://localhost:63342/test1122/a/b.html")

# js点击hidden元素

js = 'document.getElementById("baidu").click()'
driver.execute_script(js)

运行完之后,会发现页面正常的点击,跳转到百度页面了

备注:百度搜到的可能方法是先用js去掉hidden属性,再用selenium操作,这个有点多此一举,你既然都已经会用js了,何必不一次性到位直接click呢?

本文分享自微信公众号 - 从零开始学自动化测试(yoyoketang)

原文出处及转载信息见文内详细说明,如有侵权,请联系 yunjia_community@tencent.com 删除。

原始发表时间:2018-12-24

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • jenkins学习5-jenkins拉取git仓库代码,执行python自动化脚本

    python自动化的脚本开发完成后需提交到git代码仓库,接下来就是用Jenkins拉取代码去构建自动化代码了

    上海-悠悠
  • python笔记12-python多线程之事件(Event)

    前言 小伙伴a,b,c围着吃火锅,当菜上齐了,请客的主人说:开吃!,于是小伙伴一起动筷子,这种场景如何实现 一、 Event(事件) Event(事件):事件处...

    上海-悠悠
  • httprunner学习12-hook机制

    unittest框架里面有个非常好的概念:前置( setUp )和后置( tearDonw )处理器,真正会用的人不多。 HttpRunner 实际上也是从用的...

    上海-悠悠
  • python中列表的使用

    情景:列表应该是数据处理时经常使用到一种数据类型,可以有序、组合的操作值存储,是很实用的函数。。。这是最后一篇整理的笔记,发现排版很浪费时间,也得不到交流,还是...

    py3study
  • 【迄今最精密大脑连接图】“哈伯望远镜”首次看清神经网络所有连接

    【新智元导读】英国卡迪夫大学(Cardiff University)的科学家制作出了迄今最详尽的大脑连接扫描图,能够显示电信号传递的方向以及神经元间连接的密度。...

    新智元
  • 单单知道分类正确率是不够的,你可以使用更多的性能评估指标

    当你为某个分类问题建立了一个模型时,一般来说你会关注该模型的所有预测结果中正确预测的占比情况。这个性能指标就是分类正确率。

    ArrayZoneYour
  • Google 验证码进化史:我们越来越方便,但也交出了越来越多的隐私

    即使现在互联网已经渗透到我们生活的方方面面,但它依然只是现实的物理世界在虚拟的网络空间上按比特信息编码后的投射。

    猿哥
  • JS 基础知识点及常考面试题

    首先原始类型存储的都是值,是没有函数可以调用的,比如 undefined.toString()

    李才哥
  • 145号文下发:摸底互联网平台与交易所合作

    地方交易所的整治仍在继续。12月28日,深圳市互联网金融协会发布的一则通知透露,继互联网金融风险专项整治工作领导小组办公室6月下发《关于对互联网平台与各类交易场...

    企鹅号小编
  • 170亿参数加持,微软发布史上最大Transformer模型

    BERT和GPT-2之类的深度学习语言模型(language model, LM)有数十亿的参数,互联网上几乎所有的文本都已经参与了该模型的训练,它们提升了几乎...

    AI科技大本营

扫码关注云+社区

领取腾讯云代金券