在Shiny中使用renderUi中的renderDataTable

时间:2015-08-04 15:40:05

标签: r shiny renderer

我正在尝试使用Shiny App来显示动态上下文,但我无法让renderDataTable使用renderUi组件。 下面两个简单的可复制测试:第一个没有工作,第二个没有renderUi工作正常。

这两者之间的概念差异是什么,为什么第一个不能在Shiny中起作用?

这个不起作用:请注意,uiOutput myTable包含两个反应组件,selectInputrenderDataTable,但只呈现selectInput

library(shiny)
runApp(list(
    ui = fluidPage(
            fluidRow(h2("where is the table?")),
            uiOutput('myTable')
    ),
    server = function(input, output) {
            output$myTable <- renderUI({
                    fluidPage(
                            fluidRow(selectInput("test", "test", c(1,2,3))),
                            fluidRow(renderDataTable(iris))
                    )
            })
    }
))

这很好,selectInputrenderDataTable都会呈现:

library(shiny)
runApp(list(
    ui = fluidPage(
            fluidRow(h2("where is the table?")),
            fluidRow(selectInput("test", "test", c(1,2,3))),                
            fluidRow(dataTableOutput('myTable'))
    ),
    server = function(input, output) {
            output$myTable = renderDataTable(iris)
    }
))

如何让第一个场景有效?

感谢。

易慧评论后的编辑(感谢易辉):

renderUi中必须使用一些ui函数,而不是某些渲染函数: 以正确的方式更改了示例代码,结果不会改变:仍然没有显示数据。

library(shiny)
runApp(list(
    ui = basicPage(
            uiOutput('myTable')
    ),
    server = function(input, output) {
            output$myTable <- renderUI({dataTableOutput(iris)
            })
    }
))

编辑n.2

刚刚解决,让它工作如此:

library(shiny)
runApp(list(
    ui = fluidPage(
            mainPanel(

                    uiOutput('myTable')
            )
    ),
    server = function(input, output) {
            output$myTable <- renderUI({
                    output$aa <- renderDataTable(iris)
                    dataTableOutput("aa")
            })
    }
))

我必须首先将renderTableOutput保存在输出变量中,然后将其提供给dataTableOutput

感谢您指点我:here

1 个答案:

答案 0 :(得分:0)

如果你拆分datatable代和ui代的部分会更清楚:

library(shiny)
runApp(list(
    ui = fluidPage(
            mainPanel(
                    uiOutput('myTable')
            )
    ),
    server = function(input, output) {
            output$aa <- renderDataTable({iris})
            output$myTable <- renderUI({
                    dataTableOutput("aa")
            })
    }
))