Webview 方式下实现tap事件
来源:互联网 发布:mac全部色号 编辑:程序博客网 时间:2024/06/03 20:06
因为 click 事件会有一定时间的延迟,所以前端页面的开发中倾向于使用tap事件,那么在App的测试中应该怎样触发tap事件呢?
如果这个App是原生的App,可以直接使用TouchAction中的tap事件,其实用click事件也是可以触发的。TouchAction 实例化时的driver 是MobileDriver
public TouchAction(MobileDriver driver){ this.driver = driver; this.parameterBuilder = ImmutableList.builder();}
但是实际中大部分应用都是混合应用,很多是加载的h5实现的页面,定位h5 页面的元素则需要转到webview方式下,在webview模式下其实就相当于测试web页面,再使用TouchAction中的方法就不会起作用了。这时候可以使用TouchActions中的方法,注意TouchAction 是 java_client包里的,适用于AppiumDriver,而TouchActions 是 适用WebDriver的对象的,TouchActions 的一个构造函数如下:
public TouchActions(WebDriver driver) { this(((HasInputDevices) driver).getKeyboard(), ((HasTouchScreen) driver).getTouch()); }
如果此时再用AppiumDriver 对象就会报错。
网上查了很多方法,最终实现的方式是继承 AndroidDriver 类,重写HasTouchScreen 中的getTouch方法,继承AndroidDriver 的类如下:
public class AndroidTouchableDriver extends AndroidDriver implements HasTouchScreen { public RemoteTouchScreen touch; public AndroidTouchableDriver(URL URL, Capabilities Cap) { super(URL, Cap); touch = new RemoteTouchScreen(getExecuteMethod()); } @Override public TouchScreen getTouch() { return touch; }}
把所有使用AndroidDriver 实例化的 driver对象改成 AndroidTouchableDriver 进行实例化,既会保留AndroidDriver中的方法,又可以使用TouchActions 中的方法。
可以自己封装一下singleTap方法:
public void singleTap(By byElement) { TouchActions touchActions = new TouchActions(driver); WebElement element = findElement(byElement); touchActions.singleTap(element).perform(); }
使用的时候直接调用重新封装的singleTap方法即可。
另外也可以扩展ChromDriver 实现TouchActions 中的方法:
参考下面的博文:
让ChromeDriver支持TouchActions
- Webview 方式下实现tap事件
- 【CCSDS】SCPS简介及安装(Linux下TAP方式)
- 兼容tap事件
- UITextFieldDelegate和tap事件
- 封装tap事件
- linux下实现虚拟网卡TAP/TUN例子
- linux下实现虚拟网卡TAP/TUN例子
- linux下实现虚拟网卡TAP/TUN例子
- 对Webview的实现方式
- android实现:tap+activity
- sencha label 捕捉tap事件
- tap点击事件范围限制
- tap事件不响应问题
- tap 和click 事件区别
- mui的单击事件 tap
- tap 和click 事件区别
- Sencha Touch 解决 button tap事件 按下和弹起 两次响应
- 最新版Chrome模拟器下zepto的tap事件执行两次解决办法
- 值类型引用类型
- SIP模块
- CSS3实现手机1px边框,细如发丝
- 安装sense
- wamp常见问题01——局域网手机无法访问wamp下的网页
- Webview 方式下实现tap事件
- JS 判断Chrome内核的360浏览器,并禁用
- deeplearning—book—整理——rnn
- VFS
- 对于sync.Mutex使用注意事项
- 移动端测试点
- javascript HTML DOM
- 解惑rJava R与Java的高速通道
- repo回退当前分支下所有仓库到指定日期前的最新代码版本