自動化測試(4):獲取元素對象

一、元素定位簡介

八種屬性定位頁面元素:

By.ID

By.XPATH

By.LINK_TEXT

By.PARTIAL_LINK_TEXT

By.NAME

By.TAG_NAME

By.CLASS_NAME

By.CSS_SELECTOR


webdriver元素定位方法:

driver.find_element(By.XXX,'元素屬性')? # 定位單個元素

driver.find_elements(By.XXX,'元素屬性')? # 定位一組元素,返回list列表

webdriver中元素定位元素的簡便方法:

driver.find_element_by_id('元素id屬性') # ------ 最常用,簡單

driver.find_element_by_name('元素name屬性') # ------ 最常用,簡單

driver.find_element_by_class_name('元素class屬性') # ------ 易重復(fù),看情況使用

driver.find_element_by_tag_name('元素標簽名') # ------ 最不靠譜

driver.find_element_by_link_text('鏈接文本') # ------ 精確匹配鏈接 (標簽中的文字)

driver.find_element_by_partial_link_text(‘部分鏈接文本’)? # ------ 模糊匹配鏈接

driver.find_element_by_xpath()? # ------ 最靈活,萬能的靈藥

driver.find_element_by_css_selector()? # ------ 沒xpath靈活

如果需要使用簡便的方法點位一組元素,在element后加個s,如,river.find_elements_by_id() ;它返回的也是 list列表。

三、獲取頁面元素

1、id元素定位

<id="query"class="sec-input" name="query" maxlength="100" autocomplete="off" type="text">

driver.find_element_by_id(‘query’)

2、name元素定位

<name="query"maxlength="100" autocomplete="off" type="text">

driver.find_element_by_name(‘query’)

3、class name元素定位

<class="sec-input"name="query" maxlength="100" autocomplete="off" type="text">

driver.find_element_by_class_name(‘sec-input’)

4、 tag name元素定位(最不靠譜)

<input?id="query" class="sec-input" name="query" maxlength="100" autocomplete="off" type="text">

driver.find_element_by_tag_name(‘input’)

5、 link_text元素定位

頁面底部搜狗輸入法連接

<a target="_blank" class="g">關(guān)于搜狗<

driver.find_element_by_link_text('關(guān)于搜狗')

注意:連接文本是標簽對之間的文本

6、 partial link text元素定位

<a target="_blank" class="g">關(guān)于搜狗<

driver.find_element_by_partial_link_text(‘輸入法’)

7、 XPath元素定位(強大)

學習資料:http://www.w3school.com.cn/xpath/

xpath 可以根據(jù)元素的父節(jié)點或者哥哥弟弟節(jié)點定位到元素。

提取xpath方法:Chrome檢查元素窗口——鼠標右鍵copy——copy xpath

注意:使用xpath最好不要使用工具獲取,手寫的可靠性更高。

8、css元素定位

css定位元素比xpath塊,id,name,class,tag name都是轉(zhuǎn)換為css后定位元素。


參考來源:https://zhuanlan.zhihu.com/p/30673387

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容