8

我通过该icon功能在我的 Shiny 应用程序中使用了 fontawesome 图标。

我已经下载了 fontawesome 的专业版,并使用了此处的说明:shinydashboard some Font Awesome Icons Not Working将 Shiny 默认使用的免费版本(内部shiny\www\shared\font-awesome)替换为我的付费版本。这在本地运行良好,所有专业图标都显示在我的应用程序中。

但是,当我部署到 时shinyapps.io,Shiny 似乎又回到了使用默认版本。我确实尝试将我的 pro 目录包含在/www/我的应用程序的文件夹中,但没有成功。似乎没有办法告诉icon()函数查看本地版本的 fontawesome,比如icon(...,lib=local),或者icon(...,lib=path_to_fa)......

任何帮助都会非常受欢迎。

4

2 回答 2

7

诀窍是,在htmlDependency调用内部(icon()函数中),删除package = "shiny"并替换"www/shared/fontawesome"为我的 FA 文件夹的绝对路径(我还更新了版本号)。

编辑:更准确地说,下面是(非常轻微的)修改后的图标功能:

my_icon = function (name, class = NULL, lib = "font-awesome") {

prefixes <- list(`font-awesome` = "fa", glyphicon = "glyphicon")
  prefix <- prefixes[[lib]]
  if (is.null(prefix)) {
    stop("Unknown font library '", lib, "' specified. Must be one of ", 
         paste0("\"", names(prefixes), "\"", collapse = ", "))
  }
  iconClass <- ""
  if (!is.null(name)) {
    prefix_class <- prefix
    #if (prefix_class == "fa" && name %in% font_awesome_brands) {
    #  prefix_class <- "fab"
    #}
    iconClass <- paste0(prefix_class, " ", prefix, "-", name)
  }
  if (!is.null(class)) 
    iconClass <- paste(iconClass, class)
  iconTag <- tags$i(class = iconClass)
  if (lib == "font-awesome") {
    htmlDependencies(iconTag) <- htmlDependency("font-awesome", 
                                                "5.7.2", "./www/shared/fontawesome/", 
                                                stylesheet = c("css/all.min.css"))
  }
  htmltools::browsable(iconTag)
}

除了注释掉一些行之外,我唯一改变的部分是htmlDependency调用。在原始函数中,它是:

htmlDependency("font-awesome", "5.3.1", "www/shared/fontawesome", package = "shiny",
               stylesheet = c("css/all.min.css", "css/v4-shims.min.css")
于 2019-03-15T12:06:00.993 回答
5

最简单和最可靠的方法是:

  1. 将字体真棒文件放在应用程序的子目录中,www/fontawesome/

  2. 在 UI 代码的某处添加以下内容:

     htmlDependency(
       name = "font-awesome", version = "99.0",
       src = "./www/fontawesome",
       stylesheet = "css/all.min.css"
     )
    

这是一个示例应用程序,说明:

shinyApp(
  ui = fluidPage(
    "This is a Font-Awesome Pro-only icon: ", icon("acorn"),
    htmlDependency(
      name = "font-awesome", version = "99.0",
      src = "./www/fontawesome", stylesheet = "css/all.min.css"
    )
  ),
  function(input, output, session) { }
)

另一种方法的一个潜在问题是,如果ui组件包含对 的调用icon(),然后有一些动态呈现的 UI(通过renderUI()uiOutput()),其中包含对my_icon()使用仅在 Font-Awesome Pro 中的图标的调用,那么该 Pro图标不会出现。我在这里展示的方法不会有这个问题。

这就是为什么另一种方法会出现问题的原因:当ui应用程序的静态呈现为 HTML 时,它会在 中查找htmlDependency对象,并且为给定名称(在本例中为“font-awesome”)“获胜”ui的最新版本htmlDependency”。因此,如果代码中只有一个调用icon()(并且没有调用my_icon(),或者htmlDependency()在我的示例中是显式的),那么获胜的 Font-Awesome 的 htmlDependency 就是 Shiny 附带的,截至撰写本文时为 5.13.0。浏览器将请求该版本的 Font-Awesome。

稍后,如果 arenderUI()插入带有 Pro 图标的 a,HTML 将与Font-Awesome Promy_icon()的对象一起发送到浏览器。htmlDependency然而,此时浏览器已经加载了 Font-Awesome,它不会知道要加载它的新版本——Shiny 目前无法用新版本替换已经加载的 Font-Awesome 版本。

将自定义添加htmlDependency到静态ui对象使其可以在初始页面呈现时解析,并且浏览器知道从一开始就加载较新的版本。我使用的版本99.0确保了这个自定义版本将“胜过”任何其他版本的 Font-Awesome htmlDependency

于 2020-10-29T04:24:26.850 回答