轉(zhuǎn) Appium-元素定位方式

使用過 Appium 的都知道,元素的定位方式有很多種属提,具體使用哪一種权逗,主要看業(yè)務(wù)的需要和自己的使用愛好。下面總結(jié)一下冤议,Appium 到底有哪些定位方式斟薇,定位的元素以下面截圖指定的元素為例子:

這里給 Macaca 的 inspector 查看器打個廣告,的確很好用恕酸,有需要可到社區(qū)的 Macaca 版塊自己查找翱氨酢!

Appium 的定位方式種類

我說的定位方式都是基于我自己親測過蕊温,沒使用或比較少用的就在這里不列舉了袱箱,如有錯誤的地方,請多多包涵义矛!常用的定位方式(僅限 Android 和 iOS 兩種系統(tǒng))有 className发笔、id、xpath症革、AccessibilityId筐咧、AndroidUIAutomator鸯旁、iOSNsPredicateString噪矛、iOSClassChain、IosUIAutomation等

className

使用元素的className屬性定位铺罢,支持:Android 和 iOS艇挨,推薦使用。

MobileBy.className("XCUIElementTypeButton")

id

使用元素的Resource Id屬性定位韭赘,支持:Android缩滨,僅支持 Android 4.3或以上,推薦使用泉瞻。反正我沒有在 iOS 用過脉漏,大家有正確使用過的例子,可以分享一下袖牙。

MobileBy.id("package.name:id/android")

xpath

支持:Android 和 iOS侧巨。但由于 iOS 10開始使用的 XCUITest 框架原聲不支持,定位速度很慢鞭达,所以官方現(xiàn)在不推薦大家使用司忱,也有其他替代的定位方式可使用皇忿。

1.使用絕對路徑定位,如截圖所顯示的 xpath 路徑

MobileBy.xpath("className/className/className/className")

2.使用相對路徑定位

MobileBy.xpath("http://className")

3.通過元素的索引定位

MobileBy.xpath("http://className[index]")

4.通過元素的屬性定位

一種屬性:MobileBy.xpath("http://className[@label='更多信息']")

兩種屬性:MobileBy.xpath("http://className[@label='更多信息'][@isVisible='1']")

部分屬性(最強大):MobileBy.xpath("http://className[contains(@label,'更多')]")

AccessibilityId

替代以前的name定位方式坦仍,推薦使用鳍烁。

在 Android 上,主要使用元素的content-desc屬性繁扎,如該屬性為空幔荒,不能使用此定位方式。

在 iOS 上梳玫,主要使用元素的label或name(兩個屬性的值都一樣)屬性進行定位铺峭,如該屬性為空,如該屬性為空汽纠,也是不能使用該屬性卫键。

MobileBy.AccessibilityId("更多信息")

AndroidUIAutomator

僅支持 Android 4.2或以上,可支持元素的單個屬性和多個屬性定位虱朵,推薦使用莉炉。

一種屬性:MobileBy.AndroidUIAutomator("new UiSelector().text(\"發(fā)送\")")

兩種屬性:MobileBy.AndroidUIAutomator("new UiSelector().text(\"發(fā)送\").clickable(true)")

元素的所有屬性都可用做定位,功能非常強大碴犬,且速度很快絮宁。

iOSNsPredicateString

僅支持 iOS 10或以上,可支持元素的單個屬性和多個屬性定位服协,推薦使用绍昂。

一種屬性:MobileBy.iOSNsPredicateString("type == 'XCUIElementTypeButton'")

兩種屬性:MobileBy.iOSNsPredicateString("type == 'XCUIElementTypeButton' AND label == '更多信息'")

具體 iOSNsPredicate語法結(jié)構(gòu)可查看官方文檔,或查看的這個帖子:iOS 定位方式 iOSNsPredicateString 詳解偿荷。

iOSClassChain

僅支持 iOS 10或以上窘游,這是 github 的 Mykola Mokhnach 大神開發(fā),僅限在 WebDriverAgent 框架使用跳纳,用于替代 xpath 的忍饰,但使用一陣子后,感覺靈活性沒有 xpath 和 iOSNsPredicate 好寺庄,應該還不完善吧艾蓝。具體使用方法,請見:https://github.com/appium/appium-xcuitest-driver/pull/391?斗塘。

MobileBy.iOSClassChain('XCUIElementTypeWindow[1]/XCUIElementTypeOther[1]/XCUIElementTypeOther[1]/XCUIElementTypeNavigationBar[1]/XCUIElementTypeOther[1]/XCUIElementTypeButton[2]')

IosUIAutomation

僅支持 iOS 9.3或以下赢织,是 iOS 舊框架 UIAutomation 的定位方式,現(xiàn)在基本上很少使用馍盟,這個定位類型同樣可使用 iOS 謂詞進行定位于置,詳細可參考:iOSNsPredicate

總結(jié):

以上這個多定位方式,很少說全部用完朽合。根據(jù)我的經(jīng)驗俱两,推薦使用:Android:AndroidUIAutomator > className = id = AccessibilityId > xpath饱狂。iOS:iOSNsPredicateString > className = AccessibilityId

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市宪彩,隨后出現(xiàn)的幾起案子休讳,更是在濱河造成了極大的恐慌,老刑警劉巖尿孔,帶你破解...
    沈念sama閱讀 206,126評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件俊柔,死亡現(xiàn)場離奇詭異,居然都是意外死亡活合,警方通過查閱死者的電腦和手機雏婶,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,254評論 2 382
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來白指,“玉大人留晚,你說我怎么就攤上這事「娉埃” “怎么了错维?”我有些...
    開封第一講書人閱讀 152,445評論 0 341
  • 文/不壞的土叔 我叫張陵,是天一觀的道長橄唬。 經(jīng)常有香客問我赋焕,道長,這世上最難降的妖魔是什么仰楚? 我笑而不...
    開封第一講書人閱讀 55,185評論 1 278
  • 正文 為了忘掉前任隆判,我火速辦了婚禮,結(jié)果婚禮上僧界,老公的妹妹穿的比我還像新娘侨嘀。我一直安慰自己,他們只是感情好捎泻,可當我...
    茶點故事閱讀 64,178評論 5 371
  • 文/花漫 我一把揭開白布飒炎。 她就那樣靜靜地躺著,像睡著了一般笆豁。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上赤赊,一...
    開封第一講書人閱讀 48,970評論 1 284
  • 那天闯狱,我揣著相機與錄音,去河邊找鬼抛计。 笑死哄孤,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的吹截。 我是一名探鬼主播瘦陈,決...
    沈念sama閱讀 38,276評論 3 399
  • 文/蒼蘭香墨 我猛地睜開眼凝危,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了晨逝?” 一聲冷哼從身側(cè)響起蛾默,我...
    開封第一講書人閱讀 36,927評論 0 259
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎捉貌,沒想到半個月后支鸡,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 43,400評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡趁窃,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 35,883評論 2 323
  • 正文 我和宋清朗相戀三年牧挣,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片醒陆。...
    茶點故事閱讀 37,997評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡瀑构,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出刨摩,到底是詐尸還是另有隱情检碗,我是刑警寧澤,帶...
    沈念sama閱讀 33,646評論 4 322
  • 正文 年R本政府宣布码邻,位于F島的核電站折剃,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏像屋。R本人自食惡果不足惜怕犁,卻給世界環(huán)境...
    茶點故事閱讀 39,213評論 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望己莺。 院中可真熱鬧奏甫,春花似錦、人聲如沸凌受。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,204評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽胜蛉。三九已至挠进,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間誊册,已是汗流浹背领突。 一陣腳步聲響...
    開封第一講書人閱讀 31,423評論 1 260
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留案怯,地道東北人君旦。 一個月前我還...
    沈念sama閱讀 45,423評論 2 352
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親金砍。 傳聞我的和親對象是個殘疾皇子局蚀,可洞房花燭夜當晚...
    茶點故事閱讀 42,722評論 2 345

推薦閱讀更多精彩內(nèi)容