大部分類容爲轉載,原文地址:https://segmentfault.com/a/1190000010205649
定位方式
僅支持 iOS 10或以上(底層需要使用 XCUITest 框架),可支持元素的單個屬性和多個屬性定位,推薦使用。一個元素有這些屬性:type
、value
、name
、label
、enabled
、visible
,有些元素的屬性只有以上的部分屬性,如下圖所示,可根據這些屬性進行元素定位。
元素屬性的介紹
type
:元素類型,與className
作用一致,如:XCUIElementTypeStaticText
value
: 一般不用name
:元素的文本內容,可用作 AccessibilityId
定位方式,如:測試420班級羣
label
:絕大多數情況下,與 name 作用一致enabled
:元素是否可點擊,一般值爲true
或者false
visible
:元素是夠可見,一般值爲true
或者false
定位方式
元素的定位方式都是一個屬性+運算符+值
形式存在
-
比較運算符:
>,<,==,>=,<=,!=
可用於數值和字符串的比較,
如:name>100
或name == '測試'
-
範圍運算符:
IN
,BETWEEN
可用於數值和字符串的範圍覈對
如:name BETWEEN {3,10}
,name IN {'Alan','May'}
-
字符串相關:
CONTAINS
、BEGINSWITH
、ENDSWITH
包含某個字符串,如:label CONTAINS '測試'
以某個字符串開頭,如:label BEGINSWITH '420'
以某個字符串結束,如:label ENDSWITH '班級羣'
PS:在三個關鍵字後加上[c]
不區分大小寫,可用於字母的校驗;[d]
不區分發音符號,即沒有重音符號($、#、%等);[cd]
即不區分大小寫,也不區分發音符號,如:name CONTAINS[c] ABcd
和name CONTAINS abcd
、name CONTAINS ABCD
是等同的,注意後面兩個沒帶[c]
的不相等 -
通配符:
LIKE
通配符也接受[cd]
,?
代表一個字符,*
代表多個字符
如:一個元素的label
屬性爲label LIKE '420測試班級羣' label LIKE '420測?班級羣' label LIKE '420??班級羣' label LIKE '42?測試班?羣' label LIKE '*試班級羣' label LIKE '420測試班*' label LIKE '42*級羣' label LIKE '4*試*羣'
以上這麼多種文本都可以被識別爲同一個元素。
-
正則表達式:
MATCHES
如:以4
開頭,以羣
結束,label MATCHES '^4.+羣$'
PS:具體正則表達式語法,請百度一下,你就知道
以一種屬性定位元素
可以用元素的屬性:type
、value
、name
、label
、enabled
、visible
,進行定位:
type == XCUIElementTypeStaticText,
label CONTAINS '測試'
label LIKE '*試班級羣'
enabled == true
visible == false
以兩種或兩種以上屬性定位元素
就是以上單個屬性定位用符號AND
連接起來即可。如:
type == XCUIElementTypeStaticText AND label CONTAINS '測試
type == XCUIElementTypeStaticText AND label CONTAINS '測試' AND enabled == true
結合iOSClassChain使用
GitHub 上的一位大神Mykola Mokhnach開發出一套和XPath有一些共同特點的路徑表達式用於在IOS上代替XPath。
根據實際情況可以和iOSNsPredicate共同使用,比如用iOSClassChain查找某個節點,再用iOSNsPredicate再已經獲得的對象基礎上繼續查找具體元素,相關資料:https://github.com/appium/appium-xcuitest-driver/pull/391