热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

selenium点击后没反应未报错_Selenium自动化测试JavaScript定位

——————今天距2020年37天——————这是ITester软件测试小栈第83次推文做自动化过程中,会发现有的按钮点击不了,或者点击没有反应

——————·今天距2020年37天·——————

这是ITester软件测试小栈第83次推文

做自动化过程中,会发现有的按钮点击不了,或者点击没有反应,也没有报错,或者不能处理滚动条等场景,我们可以通过Javascript定位来解决这些问题。

以下总结了5种Javascript定位的方法,除了id是定位到单个element元素对象,其它的都是elements返回的是list对象。

1.通过id获取

document.getElementById(“id”)

2.通过name获取

document.getElementsByName(“Name”)

3.通过标签名选取元素

document.getElementsByTagName(“tag”)

4.通过CLASS类选取元素

document.getElementsByClassName(“class”)

5.通过CSS选择器选取元素

document.querySelectorAll(“css selector")

通过Javascript获取到元素之后,对元素的属性、内容进行操作。

  • 对属性的操作

  1. 设置属性:对象.setAttribute('属性名', '值');

  2. 获取属性:对象.getAttribute('属性名');

  3. 移除属性:对象.removeAttribute('属性名');

  • 对内容的操作

  1. 设置表单的value属性的值或元素的内容:对象.value="值";

  2. 设置指定元素标签内的文本值: 对象.innerText="值";

介绍完这些理论后,我们以实际例子来演示,比如现在用Javascript在百度搜索框输入内容。

from selenium import webdriverdriver = webdriver.Chrome()driver.get('https://www.baidu.com/')# js通过id属性获取对象,然后设置对象的值search_js = 'document.getElementById("kw").value="selenium";'driver.execute_script(search_js)

接下来,我们看下Javascript定位可以应用到哪些场景?

一通过Javascript滑动滚动条

from selenium import webdriverimport timedriver = webdriver.Chrome()driver.get('https://www.baidu.com/')driver.set_window_size(600,600)time.sleep(3)# 滚动条滑到底部scroll_bottom_js = 'document.documentElement.scrollTop=8888;'driver.execute_script(scroll_bottom_js)time.sleep(2)# 滚动条滑到顶部scroll_top_js = 'document.documentElement.scrollTop=0;'driver.execute_script(scroll_top_js)二操作日历控件   

以12306页面,出发日期的日历控件为例。我们先定位到控件,看下源码:

c222c87563052cff65dca507f15f1dfa.png

发现出发日期,有个readonly属性,这个时候我们输入不了日期,可以通过两种方法:

 1.去掉readonly属性,然后send_keys输入日期  

from selenium import webdriverimport timedriver = webdriver.Chrome()driver.get('https://www.12306.cn/index/')# 通过id属性获取元素,然后移除移除元素的readonly属性datetime_js = 'document.getElementById("train_date").removeAttribute("readonly");'driver.execute_script(datetime_js)time.sleep(2)driver.find_element_by_css_selector('input#train_date').clear()driver.find_element_by_css_selector('input#train_date').send_keys('2019-01-02')

 2.直接通过Javascript输入日期  

from selenium import webdriverimport timedriver = webdriver.Chrome()driver.get('https://www.12306.cn/index/')time.sleep(2)# 通过id属性获取元素信息,然后value改变值datetime_js = 'document.getElementById("train_date").value="2020-11-10";'driver.execute_script(datetime_js)三操作多窗口

做自动化过程中,会遇到多开页面的情况,切换多窗口会比较麻烦,这时候我可以用Javascript来处理。

我们先看下什么时候会新开页面,以百度页面的新闻链接为例,点击新闻链接会跳转到新开页面。1cbddf02cb4a7e9178ea6cd59ce0181b.png             

查看前端代码发现,target="_blank",其中_blank表示新开页面,知道了原理,那我们可以利用js去掉_blank这个属性值或者直接删除target属性。

 1.js去掉_blank属性值  

from selenium import webdriverimport timedriver = webdriver.Chrome()driver.get('https://www.baidu.com/')# js修改target值为空news_js = 'document.getElementsByClassName("mnav")[0].target="";'driver.execute_script(news_js)time.sleep(2)driver.find_element_by_link_text("新闻").click()

 2.js删除target属性  

from selenium import webdriverdriver = webdriver.Chrome()driver.get('https://www.baidu.com/')# js去掉target属性news_js = 'document.getElementsByClassName("mnav")[0].removeAttribute("target");'driver.execute_script(news_js)driver.find_element_by_link_text("新闻").click()以上That's  allITester软件测试小栈往期内容宠幸叮—这有一打让你666的测试终极资料包,请查收!

打开PyCharm永久激活的这两个锦囊,再也不用担心写代码的时候让我付费了!

Selenium自动化测试-1.selenium介绍及环境安装

Selenium自动化测试-2.浏览器基本操作

Selenium自动化测试-3.元素定位(1)

Selenium自动化测试-3.元素定位(2)

Selenium自动化测试-3.元素定位(3)

Selenium自动化测试-4.By定位及如何确定元素唯一

Selenium自动化测试-5.脚本录制神器Katalon Recorder

Selenium自动化测试-6.鼠标键盘操作

Selenium自动化测试-7.获取元素属性信息

Selenium自动化测试-8.iframe处理

Selenium自动化测试-9.设置元素等待

8970c3f59d0df3e6e9dccc2a9cc96674.png快来星标 置顶 关注

后台回复资源取干货

2ec232dbeec40e8bc08e6f1acd2ffd99.gif

7f6b7866d0ad2e0dae3e66d4deadf296.png

2ec232dbeec40e8bc08e6f1acd2ffd99.gif

9b68d31dc66fb5b92a175eb20625e2fd.gif

想要获取相关资料和软件 ?

Q群:727998947




推荐阅读
  • Redux入门指南
    本文介绍Redux的基本概念和工作原理,帮助初学者理解如何使用Redux管理应用程序的状态。Redux是一个用于JavaScript应用的状态管理库,特别适用于React项目。 ... [详细]
  • 深入理解Vue.js:从入门到精通
    本文详细介绍了Vue.js的基础知识、安装方法、核心概念及实战案例,帮助开发者全面掌握这一流行的前端框架。 ... [详细]
  • 利用Selenium与ChromeDriver实现豆瓣网页全屏截图
    本文介绍了一种使用Selenium和ChromeDriver结合Python代码,轻松实现对豆瓣网站进行完整页面截图的方法。该方法不仅简单易行,而且解决了新版Selenium不再支持PhantomJS的问题。 ... [详细]
  • 深入解析Java枚举及其高级特性
    本文详细介绍了Java枚举的概念、语法、使用规则和应用场景,并探讨了其在实际编程中的高级应用。所有相关内容已收录于GitHub仓库[JavaLearningmanual](https://github.com/Ziphtracks/JavaLearningmanual),欢迎Star并持续关注。 ... [详细]
  • 实用正则表达式有哪些
    小编给大家分享一下实用正则表达式有哪些,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下 ... [详细]
  • 简化报表生成:EasyReport工具的全面解析
    本文详细介绍了EasyReport,一个易于使用的开源Web报表工具。该工具支持Hadoop、HBase及多种关系型数据库,能够将SQL查询结果转换为HTML表格,并提供Excel导出、图表显示和表头冻结等功能。 ... [详细]
  • C#设计模式学习笔记:观察者模式解析
    本文将探讨观察者模式的基本概念、应用场景及其在C#中的实现方法。通过借鉴《Head First Design Patterns》和维基百科等资源,详细介绍该模式的工作原理,并提供具体代码示例。 ... [详细]
  • Linux系统中Java程序Too Many Open Files问题的深入解析与解决方案
    本文详细分析了在Linux环境下运行的Java应用程序中可能出现的“Too many open files”异常现象,探讨其成因及解决方法。该问题通常出现在高并发文件访问或大量网络连接场景下,对系统性能和稳定性有较大影响。 ... [详细]
  • 基于Node.js、Express、MongoDB和Socket.io的实时聊天应用开发
    本文详细介绍了使用Node.js、Express、MongoDB和Socket.io构建的实时聊天应用程序。涵盖项目结构、技术栈选择及关键依赖项的配置。 ... [详细]
  • Nginx 反向代理与负载均衡实验
    本实验旨在通过配置 Nginx 实现反向代理和负载均衡,确保从北京本地代理服务器访问上海的 Web 服务器时,能够依次显示红、黄、绿三种颜色页面以验证负载均衡效果。 ... [详细]
  • 国际高保真音乐流媒体平台的崛起:亚马逊与谷歌的竞争策略
    近期,亚马逊和谷歌正积极筹备推出高保真音乐流媒体服务,预计在2019年底前上线。根据市场研究机构CIRP的数据,截至2018年12月,美国智能音箱的安装量已增至6600万台,较第三季度增长显著。这一趋势对Spotify等传统流媒体平台构成了新的挑战。 ... [详细]
  • 如何使用Ping命令来测试网络连接?当网卡安装和有关参数配置完成后,可以使用ping命令来测试一下网络是否连接成功。以winXP为例1、打开XP下DOS窗口具体操作是点击“开始”菜 ... [详细]
  • 鼠标悬停出现提示信息怎么做
    概述–提示:指启示,提起注意或给予提醒和解释。在excel中会经常用到给某个格子增加提醒信息,比如金额提示输入数值或最大长度值等等。设置方式也有多种,简单的,仅为单元格插入批注就可 ... [详细]
  • 本文总结了优化代码可读性的核心原则与技巧,通过合理的变量命名、函数和对象的结构化组织,以及遵循一致性等方法,帮助开发者编写更易读、维护性更高的代码。 ... [详细]
  • 本文介绍如何从字符串中移除大写、小写、特殊、数字和非数字字符,并提供了多种编程语言的实现示例。 ... [详细]
author-avatar
手机用户2602889817_805
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有