1

我正在制作带有弹出窗口的传单地图。弹出窗口提供了正在选择的多边形的 ID 信息。我遇到的问题是用于 ID 的字段名称可以更改,因此我最初的方式不再适用。

这是一个可重现的示例:

## preparing the RE:
library(maps); library(sf); library(leaflet); library(htmltools)
w = st_as_sf(map('world', plot = FALSE, fill = TRUE))

我用来做的是准备一个 html 字符串来显示:

text <- paste0("<b>ID %s</b>")

sprintf然后调用传单并使用和填充弹出窗口htmlEscape

leaflet(data=w) %>% addTiles() %>% 
  addPolygons(
    popup = ~sprintf(
      text,
      htmlEscape(ID)
    )
  )

这很好用: 在此处输入图像描述

但是,该字段并不总是被称为ID,但名称是已知的并且在 ar 对象中(这里称为vari):

colnames(w) <- c("geometry", "country")
vari <- "country"

text <- paste0("<b>", vari, " %s</b>")
leaflet(data=w) %>% addTiles() %>% 
  addPolygons(
    popup = ~sprintf(
      text,
      htmlEscape(vari)
    )
  )

这不起作用: 在此处输入图像描述

我试过使用as.name它,所以它会被视为一个符号,但它不起作用:

vari <- as.name("country")

text <- paste0("<b>", vari, " %s</b>")
leaflet(data=w) %>% addTiles() %>% 
  addPolygons(
    popup = ~sprintf(
      text,
      htmlEscape(vari)
    )
  )
Error in sprintf(text, htmlEscape(vari)) : 
  invalid type of argument[1]: 'symbol'

知道如何解决吗?顺便说一句,我的 HTML 比我的示例更复杂(使用更多变量,但是,所有其他变量名称都是固定的,只有 ID 字段会更改)。

4

1 回答 1

1

我不确定这是否是您所追求的,但听起来您希望能够简单地使用来自不一定具有 name 的列中的数据填充任何弹出窗口ID,而这只是一个与标题?那么在这种情况下country呢?我担心这是一个丑陋的作弊,但鉴于您的数据结构包含一个 data.frame ,其中坐标实际上是一个列表结构,我只需测试类的数据框列,无论哪个是字符,将其用作索引并直接调用

leaflet(data=w) %>% addTiles() %>% 
  addPolygons(
    popup = ~sprintf('<b>ID %s</b>', w[[names(which(mapply(is.character, w)))]])
  )

在此处输入图像描述

于 2018-05-01T16:24:46.467 回答