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

时间:2018-01-19 11:13:19

标签: html r leaflet r-leaflet

所有善良的灵魂,需要帮助。我正在创建传单地图,无法解决标签的奇怪问题。我创建了带有少量变量的标签,如果第一个变量是数字,则标签呈现正常,但如果第一个变量是字符串则它们会失败 - 任何想法是什么问题? 让我们从虚拟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,&#34; L&#34;)我们改为(&#34; L&#34;,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标记,但不会生成标签。它有什么问题?

1 个答案:

答案 0 :(得分:3)

在玩完代码之后,我发现在purrr包中用mapply()替换map2()就可以了。我不完全确定为什么会这样。斯拉夫和我都确认这个解决方案正在我们的机器上运行。

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"))

enter image description here enter image description here