经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 程序设计 » Python » 查看文章
《最新出炉》系列入门篇-Python+Playwright自动化测试-50-滚动条操作 - 北京-宏哥
来源:cnblogs  作者:北京-宏哥  时间:2024/5/31 9:14:10  对本文有异议

1.简介

有些页面的内容不是打开页面时直接加载的,需要我们滚动页面,直到页面的位置显示在屏幕上时,才会去请求服务器,加载相关的内容,这就是我们常说的懒加载。还有就是在日常工作和学习中,经常会遇到我们的页面内容较多,一个屏幕范围无法完整展示内容,我们就需要滚动滚动条去到我们想要的地方,所以有时候我们就需要操作滚动条向下滚动的操作。其实前边的文章也提到过滚动条的操作,今天主要是将各种宏哥知道的方法进行一下汇总和总结,方便大家查找和学习。

2.通过定位元素操作滚动条

2.1原理

当页面比较长,超过浏览器的高度时候,有些元素虽然没有显示,但是实际已经加载到页面上了,只是因为滚动条未滚动至下面,所以看不到。在Chrome中可通过F12调试查看页面元素。而不是元素根本就没有,当滚动时才延迟加载。是可以直接操作的,而且playwright 在点击元素的时候,会自动滚动到元素出现的位置,这点是非常人性化的。但有些元素需要滚动到元素出现的位置,让元素处于可视的窗口上才能去操作。 或者网站是通过上拉加载的方式请求接口实现翻页的,这个时候就需要控制滚动条实现向下拖动,实现翻页的功能。Playwright提供了scroll_into_view_if_needed()方法,可以控制滚动条滚动到元素显示的位置。可使用此种方式。达到以操作滚动条的目的。

2.2示例

  1. # 页面滚动条,滚动直到此出现元素
  2. page.locator("//div[contains(@class, 'react-grid-item')][last()]").scroll_into_view_if_needed()
  3. # 元素说明:找到class里包含‘react-grid-item’属性最后一个属性

2.3实战

接下来我们以163网站为例看一下该方法的使用。

2.3.1代码设计

2.3.2参考代码
  1. # coding=utf-8??
  2.  
  3. # 1.先设置编码,utf-8可支持中英文,如上,一般放在第一行
  4.  
  5. # 2.注释:包括记录创建时间,创建人,项目名称。
  6. '''
  7. Created on 2024-03-24
  8. @author: 北京-宏哥
  9. 公众号:北京宏哥
  10. Project: 《最新出炉》系列入门篇-Python+Playwright自动化测试-50-滚动条操作
  11. '''
  12. # 3.导入模块
  13.  
  14. from playwright.sync_api import Playwright, sync_playwright, expect
  15. def run(playwright: Playwright) -> None:
  16. browser = playwright.chromium.launch(headless=False)
  17. context = browser.new_context()
  18. page = context.new_page()
  19. page.goto("https://www.163.com/")
  20. page.locator('//*[@id="lazy_subfoot_js"]/div/div/div[1]/div/div[1]/div[3]/a[5]').scroll_into_view_if_needed()
  21. page.wait_for_timeout(2000)
  22. page.close()
  23. context.close()
  24. browser.close()
  25. with sync_playwright() as playwright:
  26. run(playwright)
2.3.3运行代码

1.运行代码,右键Run'Test',就可以看到控制台输出,如下图所示:

2.运行代码后电脑端的浏览器的动作(宏哥这个定位的是最后的“国际足球”,所以滚动到底部)。如下图所示:

3.通过调用鼠标API操作滚动条

3.1原理

主要是通过解决延迟加载时间问题,之前是因为加载时间长延迟加载,不会滚动,这里通过直接缩短加载时间,间接操作滚动条。在页面中如果有两个滚动条,要操作目标滚动条,首先要使用当前光标移动至滚动条所在框中(div 、iframe等),才可以进行操作。

3.2示例

  1. # 光标移动至滚动条所在框中
  2. page.click("div.content-main")
  3. # 滚动鼠标 , 参数给一个较大值,以保证直接移动至最后
  4. page.mouse.wheel(0,10000)

3.3实战

接下来我们以163网站为例看一下该方法的使用。

3.3.1代码设计

3.3.2参考代码
  1. # coding=utf-8??
  2.  
  3. # 1.先设置编码,utf-8可支持中英文,如上,一般放在第一行
  4.  
  5. # 2.注释:包括记录创建时间,创建人,项目名称。
  6. '''
  7. Created on 2024-03-24
  8. @author: 北京-宏哥
  9. 公众号:北京宏哥
  10. Project: 《最新出炉》系列入门篇-Python+Playwright自动化测试-50-滚动条操作
  11. '''
  12. # 3.导入模块
  13.  
  14. from playwright.sync_api import Playwright, sync_playwright, expect
  15. def run(playwright: Playwright) -> None:
  16. browser = playwright.chromium.launch(headless=False)
  17. context = browser.new_context()
  18. page = context.new_page()
  19. page.goto("https://www.163.com/")
  20. # 光标移动至滚动条所在框中
  21. page.click("#ne_wrap")
  22. # 滚动鼠标 , 参数给一个较大值,以保证直接移动至最后
  23. page.mouse.wheel(0, 10000)
  24. page.wait_for_timeout(2000)
  25. page.close()
  26. context.close()
  27. browser.close()
  28. with sync_playwright() as playwright:
  29. run(playwright)
3.3.3运行代码

1.运行代码,右键Run'Test',就可以看到控制台输出,如下图所示:

2.运行代码后电脑端的浏览器的动作。如下图所示:

4.JavaScript脚本操作滚动条

4.1原理

可以使用JS语句,定位滚动条的位置到最下面,从而实现页面的向下滚动。这种方法一般来说就是终极大招,如果这个都不行,可能就没有办法了。

4.2示例

  1. page.evaluate("var q=document.documentElement.scrollTop=滚动条的位置")

4.3实战

接下来我们以163网站为例看一下该方法的使用。

4.3.1代码设计

4.3.2参考代码
  1. # coding=utf-8??
  2.  
  3. # 1.先设置编码,utf-8可支持中英文,如上,一般放在第一行
  4.  
  5. # 2.注释:包括记录创建时间,创建人,项目名称。
  6. '''
  7. Created on 2024-03-24
  8. @author: 北京-宏哥
  9. 公众号:北京宏哥
  10. Project: 《最新出炉》系列入门篇-Python+Playwright自动化测试-50-滚动条操作
  11. '''
  12. # 3.导入模块
  13.  
  14. from playwright.sync_api import Playwright, sync_playwright, expect
  15. def run(playwright: Playwright) -> None:
  16. browser = playwright.chromium.launch(headless=False)
  17. context = browser.new_context()
  18. page = context.new_page()
  19. page.goto("https://www.163.com/")
  20. page.evaluate("var q=document.documentElement.scrollTop=50000")
  21. page.mouse.wheel(0,7000)
  22. page.wait_for_timeout(2000)
  23. page.close()
  24. context.close()
  25. browser.close()
  26. with sync_playwright() as playwright:
  27. run(playwright)
4.3.3运行代码

1.运行代码,右键Run'Test',就可以看到控制台输出,如下图所示:

2.运行代码后电脑端的浏览器的动作(宏哥的滚动条的位置设置的值比较大,所以滚动到底部)。如下图所示:

5.小结

关于滚动条的操作,宏哥就分享到这里,其实还有别的方法可以实现,宏哥这里只不过列举了几种常见的操作方法,小伙伴或者童鞋们要做到举一反三,随机应变,不要死搬硬套,要灵活变通。宏哥这些方法在前边的文章中或多或少的讲解到,这里只不过对其进行总结,方便大家学习和参考。好了,时间不早了,今天就分享到这里!感谢您耐心的阅读。

原文链接:https://www.cnblogs.com/du-hong/p/17930447.html

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号