首页 > 解决方案 > 在不更改页面大小/分辨率的情况下使用 RSelenium 缩小网站

问题描述

我想缩小 RSelenium 遥控器,但这很难找到解决方案。我知道

library(RSelenium)
driver <- rsDriver()
remDr <- driver[["client"]]
remDr$navigate("https://www.google.com/")
webElem <- remDr$findElement("css", "html")
webElem$sendKeysToElement(list(key = "control", "-"))              ## Does not work
webElem$sendKeysToElement(list(key = "control", key = "subtract")) ## Does not work

浏览器是 Chrome。

标签: rseleniumselenium-webdriverrselenium

解决方案


我认为问题不在于将密钥发送到浏览器,因为如链接帖子中所述,可以发送control + a到浏览器窗口以选择元素。似乎键没有被识别为浏览器应用程序的命令。

然而,还有其他方法可以解决这个问题。

正如@Muzzamil 建议的那样,您可以通过使用 Chrome 更改文档正文的 css 来获得类似的效果,尽管这在 Firefox 中不起作用。

如果您想以在整个会话期间持续存在的方式本地更改浏览器缩放,我可以使用 Firefox 和 Chrome 演示解决方案,因为在这两种情况下,您都可以导航到基于 html 的选项页面并与之交互以设置浏览器缩放等级。

以下是使用 Firefox 的方法:

library(RSelenium)

zoom_firefox <- function(client, percent)
{
  store_page <- client$getCurrentUrl()[[1]]
  client$navigate("about:preferences")
  webElem <- client$findElement("css", "#defaultZoom")
  webElem$clickElement()
  webElem$sendKeysToElement(list(as.character(percent)))
  webElem$sendKeysToElement(list(key = "return"))
  client$navigate(store_page)
}

这允许以下操作:

driver <- rsDriver(browser = "firefox")
client <- driver$client
client$navigate("https://www.google.com")
client$screenshot(display = TRUE)

我们可以看到设置了默认缩放(100%):

在此处输入图像描述

现在我们像这样缩小到 50%:

zoom_firefox(client, 50)
client$screenshot(display = TRUE)

在此处输入图像描述 然后像这样放大:

zoom_firefox(client, 100)
client$screenshot(display = TRUE)

在此处输入图像描述

Chrome 更难,因为它的选项页面使用复杂的嵌套影子 DOM。由于我们无法获得 xpath 或 css 选择器来导航 shadow dom,我们需要使用 javascript 提取元素的 webdriver id,然后将这个 Id 强制到另一个我们可以控制的 web 元素上。

zoom_chrome <- function(client, percent)
{
  store_page <- client$getCurrentUrl()[[1]]
  client$navigate("chrome://settings/")
  webElemId <- client$executeScript(paste0("return document.querySelector",
                                           "(\"body > settings-ui\").",
                                           "shadowRoot.querySelector(\"#main\")",
                                           ".shadowRoot.querySelector",
                                           "(\"settings-basic-page\")",
                                           ".shadowRoot.querySelector",
                                           "(\"#basicPage > ",
                                           "settings-section:nth-child(8)",
                                           "> settings-appearance-page\")",
                                           ".shadowRoot.querySelector",
                                           "(\"#zoomLevel\");"),
                                    args = list("dummy"))
  webElem <- client$findElement("css", "html")
  webElem@.xData$elementId <- as.character(webElemId)
  webElem$clickElement()
  webElem$sendKeysToElement(list("3"))
  zooms <- c(25, 33, 50, 67, 75, 8:11 * 10, 125, 150, 175, 200, 250, 3:5 * 100)
  desired_zoom <- which.min(abs(percent - zooms))
  current_zoom <- which(zooms == 300)
  n_keys <- desired_zoom - current_zoom
  if(n_keys > 0) 
    for(i in seq(n_keys)) 
      webElem$sendKeysToElement(list(key = "down_arrow"))
  if(n_keys < 0) 
    for(i in seq(abs(n_keys))) 
      webElem$sendKeysToElement(list(key = "up_arrow")) 
  webElem$sendKeysToElement(list(as.character(percent)))
  webElem$sendKeysToElement(list(key = "return"))
  client$navigate(store_page)
}

但它的工作方式相同:

driver <- rsDriver(browser = "chrome", chromever = "80.0.3987.106")
client <- driver$client
client$navigate("https://www.google.com")
client$screenshot(display = TRUE)
zoom_chrome(client, 50)
client$screenshot(display = TRUE)
zoom_chrome(client, 100)
client$screenshot(display = TRUE)

这给出了与 Firefox 完全相同的结果。

当然,您可以轻松编写一个简单的包装函数,根据当前浏览器选择要调用的“缩放”函数。

我没有考虑在 Internet Explorer 或 phantomjs 中实现这一点,因为它们没有基于 html 的选项页面。


推荐阅读