从 Selenium 屏幕截图中删除滚动条

Posted

技术标签:

【中文标题】从 Selenium 屏幕截图中删除滚动条【英文标题】:Removing scrollbar from Selenium Screenshots 【发布时间】:2020-05-24 02:37:37 【问题描述】:

我正在使用 Chromedriver 获取网页的屏幕截图。我的代码运行良好。 我现在正在尝试删除丑陋的滚动条。是否可以将 CSS 注入页面?我见过几个similar questions,它们确实暗示这是可能的(“你也可以让 Chromedriver 在没有滚动条的弹出窗口中打开 url。你可以使用一些 javascript 来做到这一点。”)但没有显示这是怎么可能的。

有人知道怎么做吗?

IWebDriver driver = new ChromeDriver();
driver.Manage().Window.Size = new Size(1100, 1100);
driver.Navigate().GoToUrl("http://google.com/");
Screenshot ss = ((ITakesScreenshot)driver).GetScreenshot();

//Temp Img
string screenshot = ss.AsBase64EncodedString;
byte[] screenshotAsByteArray = ss.AsByteArray;
ss.SaveAsFile(fileNameTemp, ScreenshotImageFormat.Jpeg); 
ss.ToString();

【问题讨论】:

【参考方案1】:
    // Create a driver instance for chromedriver
    IWebDriver driver = new ChromeDriver();
    IJavaScriptExecutor js = (IJavaScriptExecutor)driver; 
    driver.Manage().Window.Size = new Size(1100, 1100);
    driver.Navigate().GoToUrl(hehe[i]);
    js.ExecuteScript("return document.body.style.overflow = 'hidden';");

成功了!

【讨论】:

和 'visible 把它们放回去 ie: object.style.overflow = "visible|hidden|scroll|auto|initial|inherit"

以上是关于从 Selenium 屏幕截图中删除滚动条的主要内容,如果未能解决你的问题,请参考以下文章

Selenium - 页面可见部分的屏幕截图

如何截取完整滚动文件的屏幕截图

css 截取没有滚动条的Squarespace网站的屏幕截图 - https://refugecf.com

使用selenium webdriver使用java [重复]查看页面源代码的屏幕截图

使用 java 使用 selenium webdriver 查看页面源的屏幕截图 [重复]

在 Selenium 2 中截取测试屏幕截图的最佳方法是啥?