2017-10-24 4 views
0

ShinyDashboardプログラムを作成していて、ダッシュボードのループを作成してMenuItemをキャッチする方法を見つける際にいくつか問題があります。これは私が修正しようとしているかの簡単な例です:tabItemダッシュボードのforループまたはlapplyループで関数を作成する方法shiny

library(shiny) 
library(shinyjs) 
library(shinydashboard) 

VecNames=c("A","B","C","D","E") 

ui <- dashboardPage(
dashboardHeader(title = "My Page"), 
dashboardSidebar(sidebarMenuOutput("sideBar_menu_UI")), 
dashboardBody(
uiOutput("body_UI"), 
uiOutput("test_UI") 
) 
) 

server <- shinyServer(function(input, output, session) { 
output$sideBar_menu_UI <- renderMenu({ 
sidebarMenu(id = "sideBar_Menu", 
      menuItem("Menu 1", tabName="menu1_tab", icon =  icon("calendar"), 
        lapply(1:length(VecNames), function(i) { 
         menuSubItem(VecNames[i], tabName = VecNames[i] ,icon = icon("angle-right")) 
        }) 
        ), 
      menuItem("Menu 2", tabName="menu2_tab", icon = icon("database")) 
) 
}) 
output$test_UI <- renderUI ({ 
A=tabItems(
    tabItem(tabName = "menu1_tab", uiOutput("menu1_UI")),  



#  lapply(1:5, function(i){ 
#  tabItem(tabName = VecNames[i], uiOutput(paste0("Menu",i)))   
#  }), 
    tabItem(tabName = VecNames[1], uiOutput(paste0("Menu",1))), 
    tabItem(tabName = VecNames[2], uiOutput(paste0("Menu",2))), 
    tabItem(tabName = VecNames[3], uiOutput(paste0("Menu",3))), 
    tabItem(tabName = VecNames[4], uiOutput(paste0("Menu",4))), 
    tabItem(tabName = VecNames[5], uiOutput(paste0("Menu",5))),  


    tabItem(tabName = "menu2_tab", uiOutput("menu2_UI")) 
) 
}) 
output$body_UI <- renderUI ({ 
p("Default content in body outsite any sidebar menus.") 
}) 
output$menu1_UI <- renderUI ({ 
box("Menu 1 Content") 
}) 
output$menu2_UI <- renderUI ({ 
box("Menu 2 Content") 
}) 

lapply(1:5, function(i){ 
output[[paste0("Menu",i)]]<- renderUI({ 
    box(paste0("Menu",i)) 
    }) 
    }) 

    }) 

runApp(list(ui= ui, server = server)) 

私は次のコードのような何かをしたいが、lapplyが

#  lapply(1:5, function(i){ 
    #  tabItem(tabName = VecNames[i], uiOutput(paste0("Menu",i)))   
    #  }) 

関数として任意の助けをのTabItemを受け入れていないようです? はあなたがtabItemsの引数としてtabItemオブジェクトのリストを使用しようとすることを、高度な

答えて

0

あなたのコードに問題があるにあなたの答えをありがとう、これはtabItemsのマニュアルに従って無効です。容器に入れて

tabItems(...)

...アイテム。各項目はtabItemでなければなりません。

do.callこの問題を解決するには、基本的には、do.callは次のように動作します。

add <- function(x, y){x + y} 
do.call(add, list(4, 3)) # same as add(4, 3) 
## 7 

は、だから、基本的に最初の引数は(tabItems)を呼び出すための関数である一方、do.callに2番目の引数としてlapplyから返されたリストを使用します。

output$test_UI <- renderUI ({ 
    items <- c(
    list(tabItem(tabName = "menu1_tab", uiOutput("menu1_UI"))), 
    lapply(1:5, function(i){ 
     tabItem(tabName = VecNames[i], uiOutput(paste0("Menu",i)))   
    }) 
) 
    do.call(tabItems, items) 
}) 
関連する問題