zoukankan      html  css  js  c++  java
  • selenium之ActionChains

    ActionChains

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

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

    ActionChains方法列表

    click(on_element=None) ——单击鼠标左键
    
    click_and_hold(on_element=None) ——点击鼠标左键,不松开
    
    context_click(on_element=None) ——点击鼠标右键
    
    double_click(on_element=None) ——双击鼠标左键
    
    drag_and_drop(source, target) ——拖拽到某个元素然后松开
    
    drag_and_drop_by_offset(source, xoffset, yoffset) ——拖拽到某个坐标然后松开
    
    key_down(value, element=None) ——按下某个键盘上的键
    
    key_up(value, element=None) ——松开某个键
    
    move_by_offset(xoffset, yoffset) ——鼠标从当前位置移动到某个坐标
    
    move_to_element(to_element) ——鼠标移动到某个元素
    
    move_to_element_with_offset(to_element, xoffset, yoffset) ——移动到距某个元素(左上角坐标)多少距离的位置
    
    perform() ——执行链中的所有动作
    
    release(on_element=None) ——在某个元素位置松开鼠标左键
    
    send_keys(*keys_to_send) ——发送某个键到当前焦点的元素
    
    send_keys_to_element(element, *keys_to_send) ——发送某个键到指定元素

    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 driver = webdriver.Chrome()
     9 driver.maximize_window()
    10 driver.get('http://ui.imdsx.cn/uitester/')
    11 time.sleep(2)
    12 driver.execute_script('window.scrollTo(0,0);')
    13 time.sleep(1)
    14 a = driver.find_element_by_css_selector('#a')  #定位元素
    15 ActionChains(driver).move_to_element(a).perform()   #鼠标移动到元素上

    click  点击 

    # 单击事件,可接受elementObj
    ActionChains(driver).click()
     
    # 双击事件,可接受elementObj
    ActionChains(driver).double_click()
     
    # 点击鼠标右键
    ActionChains(driver).context_click()
     
    # 点击某个元素不松开,接收elementObj
    ActionChains(driver).click_and_hold()
     
    # # 某个元素上松开鼠标左键,接收elementObj
    ActionChains(driver).release()

    drag_and_drop  拖拽

    # 将source元素拖放至target元素处,参数为两个elementObj
    ActionChains(driver).drag_and_drop(source=source,target=target)
     
    # 将一个source元素 拖动到针对source坐上角坐在的x y处 可存在负宽度的情况和负高度的情况
    ActionChains(driver).drag_and_drop_by_offset(source, x, y)
     
    # 这种也是拖拽的一种方式,都是以源元素的左上角为基准,移动坐标
    ActionChains(driver).click_and_hold(dom).move_by_offset(169,188).release().perform()

    举个例子

    from selenium import webdriver
    import time
    
    driver = webdriver.Chrome()
    driver.get('http://ui.imdsx.cn/uitester/')
    
    driver.execute_script('window.scrollTo(0,0);') 
    driver.maximize_window() 
    time.sleep(1)
    
    # 实现鼠标移动上去,显示点击按钮,然后单击
    # 第一种 连贯操作
    from selenium.webdriver.common.action_chains import ActionChains
    
    element = driver.find_element_by_css_selector('#a')
    element2 = driver.find_element_by_css_selector('#dis1')
    
    ActionChains(driver).move_to_element(element).click(element2).perform() #将鼠标移动到元素上,再进行点击元素,perform最后执行整个过程
    driver.switch_to.alert.accept() #弹框确认
    
    
    
    # 第二种js实现
    #修改元素的dispaly属性,使其显示出来,再点击
    js = 'document.getElementById("dis1").style.display = ""'; 
    driver.execute_script(js)
    
    time.sleep(2)
    driver.find_element_by_css_selector('#dis1').click()

    另一个例子

    # 拼图游戏
    from selenium import webdriver
    import time
    
    driver = webdriver.Chrome()
    driver.get('http://ui.imdsx.cn/move/')
    
    driver.execute_script('window.scrollTo(0,0);') 
    driver.maximize_window()
    time.sleep(1)
    
    from selenium.webdriver.common.action_chains import ActionChains
    s1 = driver.find_element_by_css_selector('#dragger')
    s2 = driver.find_element_by_css_selector('#dragger1')
    s3 = driver.find_element_by_css_selector('#dragger2')
    s4 = driver.find_element_by_css_selector('#dragger3')
    t1 = driver.find_element_by_css_selector('#i1')
    t2 = driver.find_element_by_css_selector('#i2')
    t3 = driver.find_element_by_css_selector('#i3')
    t4 = driver.find_element_by_css_selector('#i4')
    
    
    # 实例化一个类,然后往list里面添加,最后再执行
    ActionChains(driver).drag_and_drop(s1,t1).drag_and_drop(s2,t2).drag_and_drop(s3,t3).drag_and_drop(s4,t4).perform()
  • 相关阅读:
    asp.net zero 8.2 学习-9-多租户设置,发送邮件配置
    asp.net zero 8.2 学习-8-实现在页面添加、编辑、删除、查看实体
    asp.net zero 8.2 学习-7-展示实体列表,实现查询,分页,过滤,排序功能
    asp.net zero 8.2 学习-6-权限控制
    asp.net zero 8.2 学习-5-实现增删改查服务及API测试
    asp.net zero 8.2 学习-4-创建接口及服务
    asp.net zero 8.2 学习-3-添加实体,并迁移到数据库
    asp.net zero 8.2 学习-2-创建一个页面
    asp.net zero 8.2 学习-1-安装
    .net core 3.1 jwt认证
  • 原文地址:https://www.cnblogs.com/yanyan-/p/11143859.html
Copyright © 2011-2022 走看看