如果把頁面上的元素看作人的話,在現(xiàn)實世界如何找到某人呢?方法有三:

一、通過人本身的屬性,例如他的姓名,手機號,身份證號,性別,這些可區(qū)別他人的屬性。在web頁面上的元素也有這些屬性,例如,id、name、class name、tag name等。

二、在找查某人的時候可以通過位置屬性,例如,x國、x市、x路、x號。Xpath和CSS就提供了這種以標(biāo)簽名為層級關(guān)系的定位方式。

三、可以借助相關(guān)他人的屬性來找到某人,例如,我沒有小明的聯(lián)系方式,但我有他爸爸的手機號,那么通過他爸爸手機號也可以找到小明。Xpath和CSS同樣提供通過相關(guān)元素來查找最終元素的方式。

WebDriver提供多種元素定位方法,下面用Python語言來介紹這些元素定位:

1、id定位

HTML規(guī)定id屬性在HTML文檔中必須是唯一的,這類似于公民的身份證號。webdriver提供的id定位方法就是通過元素的id屬性來查找元素。例如通過id定位瀏覽器下百度輸入框與百度搜索按鈕,用法如下:

find_element_by_id("kw")      百度輸入框

find_element_by_id("su")       百度搜索

即find_element_by_id()方法通過id屬性來定位元素。

2、name定位

 HTML規(guī)定name來指定元素的名稱,就像人的姓名,所以不是唯一的。如通過name來定位百度輸入框:

find_element_by_name("wd")

即find_element_by_name()方法通過name屬性來定位元素。由于百度搜索按鈕沒有提供name屬性,故不能通過name屬性來定位它。

3、class定位

HTML規(guī)定clss來指定元素的類名。其用法與id、name類似,如通過class屬性定位百度輸入框和搜索按鈕:

find_element_by_class_name("s_ipt")

find_element_by_class_name("s_btn")

即find_element_by_class_name()方法通過class屬性來定位元素。

4、tag定位

HTML的本質(zhì)就是通過tag來定義實現(xiàn)不同的功能,每一個元素本質(zhì)上也是一個tag。因為一個tag往往用來定義一類功能,所以通過tag識別某個元素概率很低。一般一個頁面有大量的<div>、<input>、<a>等tag,所以很難通過標(biāo)tag name去區(qū)分不同元素。但有時也可以用,如通過tag name定位百度的輸入框,百度按鈕與其相同:

find_element_by_tag_name("input")

即find_element_by_tag_name()方法通過元素的tag name來定位元素。

5、link定位

link用來定位文本鏈接。如百度右上角的幾個文本鏈接的代碼如下:

通過link定位鏈接如下 :

find

網(wǎng)友評論