Selenium学习之==>ActionChainsApi接口详解

摘要:
在ActionChains UI自动测试过程中,我们经常会遇到这样的场景:鼠标悬停后,只会出现需要操作的元素。然后我们需要模拟鼠标悬停到某个位置,以进行一系列连贯的操作。Selenium为我们提供了ActionChains模块。从硒中导入方法1。webdriver。常见的action_chainsimportActionChainsmove_to_Element1#鼠标移动

ActionChains

  UI自动化测试过程中,经常遇到那种,需要鼠标悬浮后,要操作的才会元素出现的这种场景,那么我们就要模拟鼠标悬浮到某一个位置,做一系列的连贯操作,Selenium给我们提供了ActionChains模块。

引入方式

1 from selenium.webdriver.common.action_chains import ActionChains

move_to_element

 1 # 鼠标移动到某一个元素上,结束elementObj
 2 ActionChains(driver).move_to_element(e)
 3 
 4 # 鼠标移动到制定的坐标上,参数接受x,y
 5 ActionChains(driver).move_by_offset(e['x'], e['y'])
 6 
 7 例:
 8 # 鼠标悬浮操作
 9 from selenium.webdriver.common.action_chains import ActionChains
10 fl = driver.find_element_by_css_selector('#a')  # 获取鼠标要悬浮的元素
11 dis1 = driver.find_element_by_css_selector('#dis1')  # 获取要点击的按钮
12 ActionChains(driver).move_to_element(fl).click(dis1).perform() # 链式编程,可以一直点下去
 1 from selenium.webdriver.common.action_chains import ActionChains
 2 from selenium import webdriver
 3 import time
 4 driver = webdriver.Chrome()
 5 driver.maximize_window()
 6 driver.get('http://ui.imdsx.cn/uitester/')
 7 time.sleep(2)
 8 driver.execute_script('window.scrollTo(0,0);')
 9 time.sleep(1)
10 a = driver.find_element_by_id('a').location  # 获取元素坐标,返回的是一个字典
11 # {'x': 716, 'y': 112}
12 dis = driver.find_element_by_id('dis1')
13 ActionChains(driver).move_by_offset(a['x'],a['y']).double_click(dis).perform()

  实际上ActionChains这个模块的实现的核心思想就是,当你调用ActionChains的方法时,不会立即执行,而是会将所有的操作按顺序存放在一个List里,当你调用perform()方法时,队列中的时间会依次执行。

drag_and_drop

 1 # 将source元素拖放至target元素处,参数为两个elementObj
 2 ActionChains(driver).drag_and_drop(source=source, target=target)
 3 
 4 # 将一个source元素 拖动到针对source坐上角坐在的x y处 可存在负宽度的情况和负高度的情况
 5 ActionChains(driver).drag_and_drop_by_offset(source, x, y)
 6 
 7 # 这种也是拖拽的一种方式,都是以源元素的左上角为基准,移动坐标
 8 ActionChains(driver).click_and_hold(dom).move_by_offset(169, 188).release().perform()
 9 
10 例子:
11 # 拼图,拖动图片到指定位置
12 from selenium.webdriver.common.action_chains import ActionChains
13 gl = driver.find_element_by_css_selector('[href="http://t.zoukankan.com/move/"]')
14 gl.click()
15 handes = driver.window_handles
16 driver.switch_to.window(handes[1])
17 source = driver.find_element_by_css_selector('#dragger')
18 target = driver.find_element_by_css_selector('#i1')
19 source1 = driver.find_element_by_css_selector('#dragger1')
20 target1 = driver.find_element_by_css_selector('#i2')
21 source2 = driver.find_element_by_css_selector('#dragger2')
22 target2 = driver.find_element_by_css_selector('#i3')
23 source3 = driver.find_element_by_css_selector('#dragger3')
24 target3 = driver.find_element_by_css_selector('#i4')
25 # drag_and_drop 拖拽
26 ActionChains(driver).drag_and_drop(source,target).drag_and_drop(source1,target1).drag_and_drop(source2,target2).drag_and_drop(source3,target3).perform()

click

 1 # 单击事件,可接受elementObj
 2 ActionChains(driver).click()
 3  
 4 # 双击事件,可接受elementObj
 5 ActionChains(driver).double_click()
 6  
 7 # 点击鼠标右键
 8 ActionChains(driver).context_click()
 9  
10 # 点击某个元素不松开,接收elementObj
11 ActionChains(driver).click_and_hold()
12  
13 # # 某个元素上松开鼠标左键,接收elementObj
14 ActionChains(driver).release()

key_up与key_down

  有时我们需要模拟键盘操作时,那么就需要用到ActionChains中的key操作了,提供了两个方法,key_down与key_up,模拟按下键盘的某个键子,与松开某个键子,接收的参数是按键的Keys与elementObj。可以与send_keys连用(例:全选、复制、剪切、粘贴)

1 # key_down 模拟键盘摁下某个按键 key_up 松开某个按键,与sendkey连用完成一些操作,每次down必须up一次否则将出现异常
2 ActionChains(driver).key_down(Keys.CONTROL,dom).send_keys('a').send_keys('c').key_up(Keys.CONTROL)
3     .key_down(Keys.CONTROL,dom1).send_keys('v').key_up(Keys.CONTROL).perform()

Keys 实际是Selenium提供的一个键盘事件模块,在模拟键盘事件时需要导入Keys模块

引入方式

1 from selenium.webdriver.common.keys import Keys

免责声明:文章转载自《Selenium学习之==>ActionChainsApi接口详解》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇at_today git--一文弄懂git的工作区、索引区、本地仓库、远程仓库以及add、commit、push三个操作MSSQL 触发器下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

python之selenium操作隐藏元素

    Fast traslate Icon translate     getElementsByTagName   GetElementsByTagName Fast traslate Icon translate 一、html显示与隐藏元素的几种方法 1、display none:...

Python Selenium Webdriver常用方法总结

Python Selenium Webdriver常用方法总结 常用方法函数 加载浏览器驱动: webdriver.Firefox() 打开页面:get() 关闭浏览器:quit() 最大化窗口: maximize_window() 设置窗口参数:set_window_size(600,800) 后退到前一页: back() 前进到后一页: forwar...

Selenium---元素定位之CSS定位

CSS 选择器: 常见符号: #表示 id选择器 .表示 class选择器 >表示子元素,层级 一个空格也表示子元素,但是是所有的后代子元素,相当于 xpath 中的相对路径 一、css:属性定位 1.css可以通过元素的id、class、标签这三个常规属性直接定位到 2.如下是百度输入框的的html代码: <input type="text"...

selenium加载cookie报错问题:selenium.common.exceptions.InvalidCookieDomainException: Message: invalid cookie domain

在使用selenium进行自动化登录的过程中已经获取到cookie后,依旧报错:selenium.common.exceptions.InvalidCookieDomainException: Message: invalid cookie domain 获取cookie和添加cookie原代码如下: #获取cookie dr = webdriver...

Selenium自动化之鼠标双击操作

鼠标双击操作 from selenium.webdriver import ActionChains action_chains = ActionChains(self.driver) action_chains.double_click(inputBox).perform() import unittest import time from seleni...

使用selenium的方式获取网页中图片的链接和网页的链接,来判断是否是死链(二)

上一篇使用Java正则表达式来判断和获取图片的链接以及跳转的网址,这篇使用selenium的自带的API(getAttribute)来获取网页中指定的内容 实现内容:获取下面所有图片的链接地址以及跳转地址,使用get请求判断是否有死链 页面内容如图: 页面的源码,需要获取页面的href后的地址,以及src后的地址,: 代码实现可以看出图片都在一个div...