Selenium執行JavaScript腳本的方法示例

JavaScript是運行在客戶端(瀏覽器)和服務器端的腳本語言,允許將靜態網頁轉換為交互式網頁。可以通過 Python Selenium WebDriver 執行 JavaScript 語句,在Web頁面中進行js交互。那麼js能做的事,Selenium應該大部分也能做。WebDriver是模擬終端用戶的交互,所以就不能點擊不可見的元素,有時可見元素也不能點擊。在這些情況下,我們就可以通過WebDriver 執行JavaScript來點擊或者執行頁面元素。本文將介紹如何使用 WebDriver執行 JavaScript語句。

Web元素定位及操作

使用execute_script() 執行 JavaScript 代碼,有兩種方法實現元素操作

方法1:文檔級別操作

直接使用JavaScript實現元素定位和動作執行,主要方法有:

document.getElementById
document.getElementsByClassName
document.getElementsByName
document.getElementsByTagName
document.getElementsByTagNameNS

測試示例:

  • 打開百度一下
  • 輸入框輸入”test“
  • 點擊百度一下

python代碼:

def test_baidu(self):
  self.driver.get("http://www.baidu.com")
  self.driver.execute_script('document.getElementById("kw").value = "test"')
  time.sleep(2)
  self.driver.execute_script('document.getElementById("su").click()')
  time.sleep(2)

在執行過程中,WebDriver 將 JavaScript 語句註入到瀏覽器中,然後腳本將執行。這個註入 JavaScript 有自己的名稱空間,不會幹擾實際網頁中的 JavaScript運行。

方法2:元素級別操作

可以先使用WebDriver獲取想要操作的元素,然後使用JavaScript執行操作。

input_ele = driver.find_element_by_id("su") 
driver.execute_script("arguments[0].click();", input_ele)

python代碼:

def test_baidu2(self):
  self.driver.get("http://www.baidu.com")
  input_ele = self.driver.find_element_by_id("kw")
  self.driver.execute_script("arguments[0].value = 'test';", input_ele)
  time.sleep(2)
  baidu_ele = self.driver.find_element_by_id("su")
  self.driver.execute_script("arguments[0].click();", baidu_ele)
  time.sleep(2)

可以在語句中使用多個 JavaScript動作:

username = driver.find_element_by_xpath("//*[@id='username']")
password = driver.find_element_by_xpath("//*[@id='password']")
driver.execute_script("arguments[0].value = 'admin';arguments[1].value = 'admin';", username, password)

獲取返回值

可以返回JavaScript的執行結果:

driver.execute_script("return document.getElementById('kw').value")
driver.execute_script("return document.title;") # 返回網頁標題

滑動

在 Web自動化測試 | ActionChains、TouchAction 中介紹瞭TouchAction類中scroll_from_element()也可以滑動頁面。

滑動到瀏覽器底部

document.documentElement.scrollTop=10000
window.scrollTo(0, document.body.scrollHeight)

滑動到瀏覽器頂部

document.documentElement.scrollTop=0
window.scrollTo(document.body.scrollHeight,0)

更改元素屬性

大部分時間控件都是 readonly屬性,需要手動去選擇對應的時間。自動化測試中,可以使用JavaScript代碼取消readonly屬性。

測試頁面: https://www.12306.cn/index/

測試步驟:

  • 打開測試頁面
  • 修改出發日期
  • 斷言日期是否修改成功

python測試代碼:

def test_datettime(self):
  self.driver.get("https://www.12306.cn/index/")
  # 取消readonly屬性
  self.driver.execute_script("dat=document.getElementById('train_date'); dat.removeAttribute('readonly')")  
  self.driver.execute_script("document.getElementById('train_date').value='2020-10-01'")
  time.sleep(3)
  now_time = self.driver.execute_script("return document.getElementById('train_date').value")
  assert '2020-10-01' == now_time

總結

Selenium WebDriver 執行 JavaScript代碼是一個非常強大的功能,可以實現WebElement 接口所有功能,甚至更多的功能。比如在web性能測試中可以調用Web API接口window.performance來測試Web性能。

到此這篇關於Selenium執行JavaScript腳本的方法示例的文章就介紹到這瞭,更多相關Selenium執行JavaScript腳本內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!

推薦閱讀: