受this answer的启发,我想在R中使用此数据框
input <- data.frame(text = c("a", "b", "c"),
page_number = c(3, 5, 6))
根据文本创建一个列表,该列表链接到不同的page_numbers。该解决方案描述了如何在Markdown中使用JavaScript,但不幸的是,没有在代码块中使用它(动态创建列表是必需的)。
答案 0 :(得分:1)
我喜欢将htmltools
包用于这种工作。
您可以使用htmltools::a()
创建HTML锚点。
为了创建幻灯片#2的链接,您需要编写:
htmltools::a("text", href = "javascript:slidedeck.loadSlide(2)")
您可以轻松地矢量化此表达式。不要忘记将结果列表传递给htmltools::tagList()
。
这是最小Rmd,并带有问题中引用的示例:
---
title: "Presentation"
output: ioslides_presentation
---
## Slide 1 - page 2
This is the first slide. With links to other slides:
```{r echo=FALSE}
input <- data.frame(text = c("a", "b", "c"),
page_number = c(3, 5, 6))
htmltools::tagList(
mapply(
htmltools::a,
input$text,
href = sprintf("javascript:slidedeck.loadSlide(%i)", input$page_number),
SIMPLIFY = FALSE)
)
```
\
If you prefer the tidyverse:
```{r echo=FALSE, message=FALSE}
library(tidyverse)
tribble(
~text, ~page_number,
"a", 3,
"b", 5,
"c", 6
) %>%
transmute(
text,
href = str_glue("javascript:slidedeck.loadSlide({page_number})")
) %>%
pmap(~ htmltools::a(.x, href = .y)) %>%
htmltools::tagList()
```
## Slide 2 - page 3
Text for slide 2
## Slide 3 - page 4
Text for slide 3
## Slide 4 - page 5
Text for slide 4
## Slide 5 - page 6
Text for slide 4
答案 1 :(得分:0)
对不起,我无法发表评论,但您是否需要JavaScript代码块? 如果是这样,这对您有帮助吗?
第一
install.package(knitr)
然后在您的R Markdown文件中:
```{r setup, include=FALSE}
knitr::opts_chunk$set(echo = TRUE)
library(knitr)
```
和
```{js}
some javascript code in here
```
答案 2 :(得分:0)
最简单的方法是在创建所需原始字符串的代码块上使用results='asis'
。您可以将其包装到原始HTML块中,以确保它不会被视为Markdown而是被视为HTML。
~~~{=html}
```{r, echo=FALSE, results='asis'}
input <- data.frame(text = c("a", "b", "c"),
page_number = c(3, 5, 6))
links <- paste('<a href="', input$text, '">', input$page_number, "</a>", sep="")
cat(links, sep = "\n")
```
~~~