——————·今天距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 webdriver
driver = 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 webdriver
import time
driver = 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页面,出发日期的日历控件为例。我们先定位到控件,看下源码:

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

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

from selenium import webdriver
import time
driver = 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 webdriver
import time
driver = 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来处理。

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

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

1.js去掉_blank属性值

from selenium import webdriver
import time
driver = 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 webdriver
driver = 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  all

ITester软件测试小栈

往期内容宠幸

叮—这有一打让你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.设置元素等待

快来星标 置顶 关注我

后台回复资源取干货

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

Q群:727998947

Selenium自动化测试-JavaScript定位相关推荐

  1. Selenium自动化测试-元素定位的八种方法,你知道的有几种?

    大家好 我就是那个人见人爱,花见花开的阿里大叔 今天继续selenium系列 实例示范 即学即用 学成之后 你就是整条gai最靓的仔 这次我们要分享的是对元素的定位,在一个页面中有很多不同的策略来定位 ...

  2. Selenium自动化测试系列文章汇总

    selenium系列文章汇总 Selenium自动化测试-selenium介绍及环境安装 Selenium自动化测试-浏览器基本操作 Selenium自动化测试-元素定位(1) Selenium自动化 ...

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

    ------·今天距2020年80天·------ 这是ITester软件测试小栈第56次推文 大家好 我是vivi小胖虎 今天是周六 然而又是上班的一天 不管怎样 学习的心态总是要有的 争取早日当上 ...

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

    ------·今天距2020年81天·------ 这是ITester软件测试小栈第55次推文 大家好 我是vivi小胖虎 前面已经介绍过7种元素定位方法 相信这些积攒堆积起来的技巧 都会在实际工作时 ...

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

    ------·今天距2020年82天·------ 这是ITester软件测试小栈第54次推文 大家好 我是vivi小胖虎 今天我们学习xpath定位元素 如果你告诉我 不是你不想用selenium做 ...

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

    ------·今天距2020年83天·------ 这是ITester软件测试小栈第53次推文 大家好 我是vivi小胖虎 今天继续selenium系列 实例示范 即学即用 学成之后 你就是整条gai ...

  7. Selenium自动化测试:8种元素定位+unittest框架设计

    作者简介: 笔名,唐米.参与过汇丰银行,国家电网,中国电信等多个大型项目的研发和管理,擅长的技术领域为安全测试,性能测试,自动化框架搭建与维护,曾受南京航空航天大学邀请分享Linux.oracle等测 ...

  8. python写界面输入测试脚本_python+Selenium自动化测试——输入,点击操作

    这是我的第一个真正意思上的自动化脚本. 1.练习的测试用例为: 打开百度首页,搜索"胡歌",然后检索列表,有无"胡歌的新浪微博"这个链接 2.在写脚本之前,需要 ...

  9. 《Selenium自动化测试指南》—第1章1.1节自动化测试基础

    本节书摘来自异步社区<Selenium自动化测试指南>一书中的第1章1.1节自动化测试基础,作者赵卓,更多章节内容可以访问云栖社区"异步社区"公众号查看. 1.1 自动 ...

最新文章

  1. 拖拽公式图片、一键转换LaTex公式,这款开源公式识别神器比Mathpix Snip更适合你...
  2. Snmp在Windows下的实现----WinSNMP编程原理
  3. Linux纯干货知识总结|面试专用
  4. jgroups传输消息_使用JGroups进行ElasticMQ消息复制
  5. flex 解析json文件_使用 Python 处理 JSON 格式的数据 | Linux 中国
  6. Node.js笔记-使用nodejs-websocket构建WebSocket服务
  7. 大数四则运算java(转)
  8. 基于 Linux 和 MiniGUI 的嵌入式系统软件开发指南(一)(转)
  9. ASP.NET MVC的最佳日志记录库
  10. 【算法学习】纯高斯模糊算法处理灰度图片
  11. Win10 系统通过易升升级后,系统盘空间不足解决办法(个人经历)
  12. c语言开发 kdj,KDJ——随机指标之王
  13. 被罚6500万,“偷税人”雪梨还能直播吗?
  14. Mybatis如果存在该条数据则修改,否则新增
  15. android ios9 rom,谁说安卓不如苹果?看Android7.0如何逆袭iOS9.3
  16. Oracle练习题(九)
  17. 服务器win10系统怎样共享,win10系统开启局域网共享
  18. BIN,S19,M0T,SREC,HEX文件解析;FileParse(二)之源码解析
  19. selenium java框架_自动化测试框架selenium+java+TestNG——配置篇
  20. SpringBoot集成aspose实现cad、word、excle、ppt在线预览

热门文章

  1. 括号配对问题----栈模拟
  2. 小程序php支付,前后端分离
  3. oracle trace跟踪,浅析Oracle追踪工具SQL Trace的启用方式
  4. pv原语模拟实现_HART协议压力变送器硬件设计及实现
  5. linux打开core文件,[转载]linux下core文件设置与查看
  6. linux性能评估-内存基础理解篇
  7. 算法第五章上机实践报告
  8. myeclipse 2017 CI 中如何修改Servlet模板
  9. 递归算法造成的问题分析与解决
  10. 搭建 OpenStack 实验环境 - 每天5分钟玩转 OpenStack(16)