原生定位
https://developer.android.com/reference/android/support/test/uiautomator/UiSelector.html
WebElement element =driver.findElement(
AppiumBy.androidUIAutomator("new UiSelector().resourceId(\"com.xueqiu.android:id/stock_layout\")")
)
driver.findElement(
AppiumBy.androidUIAutomator("new UiSelector().resourceId(\"com.xueqiu.android:id/tab_name\").text(\"股票\")"))
css selector 定位
- 官网说明:
Release v1.19.0 · appium/appium · GitHub
- Android: Appium Server 版本 >= 1.19.0
- iOS:Appium Server>= 1.21.0
- css selector 会转化为 Android/iOS 原生定位的定位策略
- Android 转为 Android Uiautomator 定位方式
- iOS 转为 class chain 定位方式
- css selector 用法
# id 定位转化:
elementsById("someResourceID") --> elementsByCss("#someResourceID")
# class name 定位转化:
elementsByClassName("android.widget.TextView") --> elementsByCss("android.widget.TextView")
# accessibility id 定位转化:
elementsByAccessibilityId("Some Content Description") --> elementsByCss('*[description="Some Content Description"]')
# xpath 定位转化:
elementsByXpath("//android.widget.TextView[@description='Accessibility']") --> elementsByCss("android.widget.TextView[description='Accessibility']")
# 代码:
driver.findElement(
AppiumBy.cssSelector("#com\\.xueqiu\\.android\\:id\\/home_search"));
# 解析前:
{"using":"css selector",
"value":"#com\\.xueqiu\\.android\\:id\\/home_search"}
# 解析后:
{"strategy":"-android uiautomator",
"selector":"new UiSelector()
.resourceId(\"com.xueqiu.android:id/home_search\")",...}