『心善淵』Selenium3.0基礎(chǔ) — 21.Selenium操作瀏覽器窗口滾動(dòng)條

1轿衔、為什么操作滾動(dòng)條

  1. 在HTML頁(yè)面中沉迹,由于前端技術(shù)框架的原因,頁(yè)面中的一些元素為動(dòng)態(tài)顯示害驹,元素根據(jù)滾動(dòng)條的下拉而被加載鞭呕。

  2. 例如:頁(yè)面注冊(cè)同意條款,需要滾動(dòng)條到最底層宛官,才能點(diǎn)擊同意葫松。

2、Selenium如何操作滾動(dòng)條

SeleniumWebDriver類(lèi)庫(kù)中并沒(méi)有直接提供對(duì)滾動(dòng)條進(jìn)行操作方法底洗,但是Selenium提供了可調(diào)用JavaScript腳本的方法腋么,所以我們可以通過(guò)JavaScript腳本來(lái)達(dá)到操作滾動(dòng)條的目的。

提示:

  • 滾動(dòng)條:一種可控制程序顯示范圍的組件亥揖。
  • JavaScript:一種流行腳本語(yǔ)言珊擂,可以操作HTML標(biāo)簽。

JavaScript學(xué)習(xí)文檔:http://www.w3school.com.cn/js/js_intro.asp

3徐块、Selenium操作滾動(dòng)條方法

  1. 設(shè)置JavaScritp腳本控制滾動(dòng)條

    js="window.scrollTo(0,1000)

    (0:水平距離未玻;1000:垂直距離;單位像素px)

  2. WebDriver調(diào)用JavaScritp腳本方法

    driver.execute_script(js)

提示:

  • 最頂層

js="window.scrollTo(0,0)"

  • 最底層

js="window.scrollTo(0,1000)"

注:1000不代表一定到最底層胡控,要根據(jù)瀏覽器頁(yè)面的實(shí)際大小扳剿。

  • 直接操作垂直距離的方式

js= "var q=document.documentElement.scrollTop=n

4、練習(xí)

需求:訪問(wèn)淘寶首頁(yè)昼激,在淘寶首頁(yè)實(shí)現(xiàn)Selenium對(duì)滾動(dòng)條的操作庇绽。

腳本代碼:

"""
1.學(xué)習(xí)目標(biāo):
    掌握瀏覽器滾動(dòng)條的操作方法
2.語(yǔ)法
    2.1使用js語(yǔ)言編寫(xiě)控制滾動(dòng)條代碼
        參數(shù):
            0,表示水平距離;
            10000,表示垂直距離  單位:px
        格式:
            向下滾動(dòng):window.scrollTo(0,10000)
            向上滾動(dòng):window.scrollTo(0,0)
    2.2使用selenium中方法執(zhí)行js代碼
        driver.execute_script(js代碼)
3.需求
    在頁(yè)面中,控制滾動(dòng)條
4.總結(jié)
    如果需要測(cè)試寫(xiě)的js代碼,可以在瀏覽器F12,控制臺(tái)console中執(zhí)行查看結(jié)果橙困。
"""
# 1.導(dǎo)入selenium
from selenium import webdriver
from time import sleep

# 2.打開(kāi)瀏覽器
driver = webdriver.Chrome()

# 3.打開(kāi)頁(yè)面
url = "https://www.taobao.com"
driver.get(url)
sleep(2)

# 4.滾動(dòng)條操作
# 4.1 滾動(dòng)條向下滾動(dòng)
js_down = "window.scrollTo(0,1000)"
# 執(zhí)行向下滾動(dòng)操作
driver.execute_script(js_down)
sleep(2)

# 4.2 滾動(dòng)條向上滾動(dòng)
js_up = "window.scrollTo(0,0)"
driver.execute_script(js_up)
sleep(2)

# 向下滾動(dòng)操作
# n為從頂部往下移動(dòng)滾動(dòng)距離
js1 = "var q=document.documentElement.scrollTop=2000"
driver.execute_script(js1)
sleep(2)

# 5.關(guān)閉瀏覽器
driver.quit()

5瞧掺、下拉至聚焦元素的位置

聚焦元素:就是把滾動(dòng)條滾動(dòng)到你想要查找的元素的位置

步驟:

# 1 定位需要聚焦元素
target = driver.find_element_xx

# 2 js代碼
js = "arguments[0].scrollIntoView()"

# 3 執(zhí)行聚焦元素操作
driver.execute_script(js代碼,元素target)

示例:

頁(yè)面代碼片段

<!DOCTYPE html>
<html lang="zh-cn">
<head>
    <meta charset="UTF-8">
    <style type="text/css">
        button{padding: 8px; background: #f8f8f8;border-radius: 5px}
        button{margin-left:200px;margin-top:2000px}
    </style>
</head>
<body>
    <button type="submitA" value="注冊(cè)A" title="加入會(huì)員A" >注冊(cè)用戶A</button>
</body>
</html>

腳本代碼:

"""
1.學(xué)習(xí)目標(biāo):
    掌握聚焦元素的操作方法
2.語(yǔ)法(操作方法)
    2.1 定位需要聚焦元素
        target = driver.find_element_xx
    2.2 js代碼
        js = "arguments[0].scrollIntoView()"
    2.3 執(zhí)行聚焦元素操作
        driver.execute_script(js代碼,元素target)
3.需求
    在頁(yè)面中,滾動(dòng)條下拉聚焦元素位置。
"""
# 1.導(dǎo)入selenium
from selenium import webdriver
from time import sleep
import os

# 2.打開(kāi)瀏覽器
driver = webdriver.Chrome()

# 3.打開(kāi)頁(yè)面
url = "file:///" + os.path.abspath("./1.html")
driver.get(url)
sleep(2)

# 4.滾動(dòng)條下拉聚焦元素位置
# 4.1 定位需要聚焦元素-淘寶首頁(yè)的END文字
element = driver.find_element_by_css_selector("[type='submitA']")

# 4.2 js代碼
js = "arguments[0].scrollIntoView()"

# 4.3 執(zhí)行聚焦元素操作
driver.execute_script(js, element)
sleep(3)

# 5.關(guān)閉瀏覽器
driver.quit()
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末凡傅,一起剝皮案震驚了整個(gè)濱河市辟狈,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌夏跷,老刑警劉巖哼转,帶你破解...
    沈念sama閱讀 210,914評(píng)論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異槽华,居然都是意外死亡壹蔓,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 89,935評(píng)論 2 383
  • 文/潘曉璐 我一進(jìn)店門(mén)猫态,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)佣蓉,“玉大人披摄,你說(shuō)我怎么就攤上這事∮缕荆” “怎么了疚膊?”我有些...
    開(kāi)封第一講書(shū)人閱讀 156,531評(píng)論 0 345
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)虾标。 經(jīng)常有香客問(wèn)我酿联,道長(zhǎng),這世上最難降的妖魔是什么夺巩? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 56,309評(píng)論 1 282
  • 正文 為了忘掉前任贞让,我火速辦了婚禮,結(jié)果婚禮上柳譬,老公的妹妹穿的比我還像新娘喳张。我一直安慰自己,他們只是感情好美澳,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,381評(píng)論 5 384
  • 文/花漫 我一把揭開(kāi)白布销部。 她就那樣靜靜地躺著,像睡著了一般制跟。 火紅的嫁衣襯著肌膚如雪舅桩。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 49,730評(píng)論 1 289
  • 那天雨膨,我揣著相機(jī)與錄音擂涛,去河邊找鬼。 笑死聊记,一個(gè)胖子當(dāng)著我的面吹牛撒妈,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播排监,決...
    沈念sama閱讀 38,882評(píng)論 3 404
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼狰右,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了舆床?” 一聲冷哼從身側(cè)響起棋蚌,我...
    開(kāi)封第一講書(shū)人閱讀 37,643評(píng)論 0 266
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎挨队,沒(méi)想到半個(gè)月后谷暮,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,095評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡瞒瘸,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,448評(píng)論 2 325
  • 正文 我和宋清朗相戀三年坷备,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了熄浓。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片情臭。...
    茶點(diǎn)故事閱讀 38,566評(píng)論 1 339
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡省撑,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出俯在,到底是詐尸還是另有隱情竟秫,我是刑警寧澤,帶...
    沈念sama閱讀 34,253評(píng)論 4 328
  • 正文 年R本政府宣布跷乐,位于F島的核電站肥败,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏愕提。R本人自食惡果不足惜馒稍,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,829評(píng)論 3 312
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望浅侨。 院中可真熱鬧纽谒,春花似錦、人聲如沸如输。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,715評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)不见。三九已至澳化,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間稳吮,已是汗流浹背缎谷。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,945評(píng)論 1 264
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留灶似,地道東北人慎陵。 一個(gè)月前我還...
    沈念sama閱讀 46,248評(píng)論 2 360
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像喻奥,于是被迫代替她去往敵國(guó)和親席纽。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,440評(píng)論 2 348