javascript - 如何在 R Shiny 中查询元素

标签 javascript html r shiny

我想根据 HTML 标签查询我的 Shiny 应用程序中的元素。例如,对于以下应用程序,如何访问所有 h1 元素(包括其标签和 id)?

library(shiny)
ui <- fluidPage(
  h1("Get", id = "1"),
  h1("this", id = "2"),
  h2("But", id = "3"),
  h3("not", id = "4"),
  h4("that", id = "5")
)

server <- function(input, output) {}

shinyApp(ui = ui, server = server)

最佳答案

当您在问题中标记javascript时,找到基于shinyJS/JS的解决方案。

您可以使用以下代码来标识 h1 元素:

var elements = document.getElementsByTagName('h1');
var sendToR = [];
for (var nr = 0; nr < elements.length; nr++) {
    var newElement = {};
    newElement['id'] = elements[nr].id;
    newElement['text'] = elements[nr].textContent;
    sendToR.push(newElement);
}

然后您可以通过以下方式将结果“发送”到 R:

Shiny.onInputChange('h1', sendToR)

并在 R 端接收:

observe({
    print(input$h1)
  })

可重现的示例:

library(shiny)
library(shinyjs)

ui <- fluidPage(
  useShinyjs(),
  h1("Get", id = "1"),
  h1("this", id = "2"),
  h2("But", id = "3"),
  h3("not", id = "4"),
  h4("that", id = "5")
)

server <- function(input, output) {
  observe({
    runjs("
      var elements = document.getElementsByTagName('h1');
      var sendToR = [];
      for (var nr = 0; nr < elements.length; nr++) {
          var newElement = {};
          newElement['id'] = elements[nr].id;
          newElement['text'] = elements[nr].textContent;
          sendToR.push(newElement);
      }
      Shiny.onInputChange('h1', sendToR)
    ")
  })

  observe({
    print(input$h1)
  })
}

shinyApp(ui = ui, server = server)

关于javascript - 如何在 R Shiny 中查询元素,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56458174/

相关文章:

javascript - 没有闰日的两个日期之间的差异

HTML:我该怎么做...!

html - 隐藏表格数据时表格无法正常显示

r - gtrendsR 查询的问题

r - 仅使用第二个键选择 data.table 中的行

r - 聚类一个大数据集(定量/定性值)

javascript - 如何将 addClass 应用于父级的父级?

javascript - 如何使用 React 测试库测试 React 组件是否返回 null 或其子级?

javascript - 如何通过输出 Vowels(str) 来编写函数,该函数获取随机字符串作为参数

用于汇总连接到复选框的价格的 JavaScript 函数?