带有 HTML 标签的传单 r 中的标签

labels in leaflet r with HTML tags

所有善良的人,需要帮助。我正在创建传单地图,但无法解决标签的奇怪问题。我创建了几个变量的标签,如果第一个变量是数字,标签渲染正常,但如果第一个变量是字符串,它们就会失败——知道有什么问题吗? 让我们从一个虚拟的 spdf 开始:

library(htmltools)
library(sp)
library(leaflet)

df <- new("SpatialPointsDataFrame", data = structure(list(PMID = c(184397, 184397), SPACEID = c("184397_1", "184397_2")), .Names = c("PMID", "SPACEID"), row.names = 1:2, class = "data.frame"), coords.nrs = numeric(0), coords = structure(c(-0.14463936, -0.14468822, 51.50726534, 51.50730171), .Dim = c(2L, 2L), .Dimnames = list(c("1", "2"), c("x", "y"))), bbox = structure(c(-0.14468822, 51.50726534, -0.14463936, 51.50730171), .Dim = c(2L, 2L), .Dimnames = list(c("x", "y"), c("min", "max"))), proj4string = new("CRS", projargs = "+proj=longlat +datum=WGS84 +no_defs +ellps=WGS84 +towgs84=0,0,0"))

现在我们 (m) 应用一个简单的 HTML 行(原来使用 df 行,但不需要它,可以简化为

df@data$HT<-mapply(function(x,y){htmltools::HTML(sprintf("<h2>%s</h2> %s",x,y))},1,"L", SIMPLIFY = F) 

这个会很好用。但是如果顺序颠倒——而不是 (1,"L") 我们改为 ("L",1) - 它失败了:

df@data$HT<-mapply(function(x,y){htmltools::HTML(sprintf("<h2>%s</h2> %s",x,y))},"L",1, SIMPLIFY = F) 

在第一种情况下,地图包含正确的标签,而在另一种情况下,它生成空标签

leaflet() %>%
addTiles() %>%
addMarkers(data = df, label = ~ HT)

如果我使用 label = ~as.character(HT),它会生成一个逐字的 HTML 标签,而不是标签。怎么了?

玩完代码后,我发现将 purrr 包中的 mapply() 替换为 map2() 就可以解决问题。我不完全确定为什么会这样。 Slav 和我都确认这个解决方案在我们的机器上工作。

library(sp)
library(leaflet)
library(htmltools)
library(purrr)

df@data$HT1 <- map2(1, "L", ~htmltools::HTML(sprintf("<h2>%s</h2> %s",.x,.y))) 
df@data$HT2 <- map2("L", 1, ~htmltools::HTML(sprintf("<h2>%s</h2> %s",.x,.y))) 

leaflet()%>%
addProviderTiles("OpenStreetMap.Mapnik") %>%
addLabelOnlyMarkers(data = df, label = ~HT2, 
                    labelOptions = labelOptions(noHide = TRUE, direction = 'center',
                                                textOnly = FALSE, textsize = "15px"))