根据滑块输入选择要在数据表中显示的行数

Wil*_*car 4 r shiny dt

我正在尝试使用滑块输入选择要在数据表中显示的行数。

这是我的应用程序的 pageLength 为 2

library(shiny)
library(DT)

# Dummy data 
dataset <- data.frame(lng = c(-5, -5, -5, -5, -15, -15, -10),
             lat = c(8, 8, 8, 8, 33, 33, 20),
             year = c(2018, 2018, 2018, 2017, 2017, 2017, 2016),
             type = c('A', 'A', 'A', 'A', 'B', 'B', 'A'),
             id =c("1", "1", "1", "1", "2", "2", "3"))


ui <- fluidPage(

  sidebarLayout(
  sidebarPanel(
     sliderInput("rows",
                 "Number of rows",
                 min = 1,
                 max = 50,
                 value = 1)
  ),

 # datable output 
     DT::dataTableOutput(outputId =  "table")
  )
 )
)

 server <- function(input, output) {



        output$table <- DT::renderDataTable(
            dat <- datatable(dataset,
                             options = list(
                               paging =TRUE,
                               pageLength =  2 
                               )
                             )
            )

        }

        # Run the application 
        shinyApp(ui = ui, server = server)
Run Code Online (Sandbox Code Playgroud)

我在服务器端尝试过的: 1. 首先,我尝试将其 sliderInput$rows用作 pageLength 的参数: pageLength = sliderInput$rows

  1. 我也在服务器端尝试过:

     server <- function(input, output) {
    
      i <- reactive({sliderInput$rows})
    
      output$table <- DT::renderDataTable(
        dat <- datatable(dataset,
                         options = list(
                           paging =TRUE,
                           pageLength =  i() 
                         )
        )
      )
    
    }
    
    Run Code Online (Sandbox Code Playgroud)

Wil*_*car 6

根据 Aurèle 评论,这是我更新的服务器端:

服务器 <- 功能(输入,输出){

    output$table <- DT::renderDataTable(
        dat <- datatable(dataset,
                         options = list(
                           paging =TRUE,
                           pageLength =  input$rows 
                           )
                         )
        )

    }
Run Code Online (Sandbox Code Playgroud)