闪亮:使用 shinyjs 禁用 tabPanel()
Shiny: Disable tabPanel() using shinyjs
我正在使用@SriPaladugu 提供的答案 here 来禁用 tabPanel()
并且我注意到如果 tabPanel(title,...)
中存在 space 它就不起作用.他们编写了自己的 JavaScript 代码并使用 shinyjs
到 enable/disable 面板,我不熟悉 JavaScript 代码来解决这个问题。他们执行此操作的代码存储在对象 jscode
中;如何修改代码以说明 tabPanel(title,...)
中的 space?
library(shiny)
library(shinyjs)
jscode <- "
shinyjs.disableTab = function(name) {
var tab = $('.nav li a[data-value=' + name + ']');
tab.bind('click.tab', function(e) {
e.preventDefault();
return false;
});
tab.addClass('disabled');
}
shinyjs.enableTab = function(name) {
var tab = $('.nav li a[data-value=' + name + ']');
tab.unbind('click.tab');
tab.removeClass('disabled');
}
"
css <- "
.nav li a.disabled {
background-color: #aaa !important;
color: #333 !important;
cursor: not-allowed !important;
border-color: #aaa !important;
}"
ui <- shinyUI(fluidPage(
shinyjs::useShinyjs(),
shinyjs::extendShinyjs(text = jscode, functions = c("disableTab","enableTab")),
shinyjs::inlineCSS(css),
navbarPage("Test",id="navbarPage",
tabPanel("FirstTab", id = "first_tab",
sidebarLayout(
sidebarPanel(),
mainPanel()
)
),
tabPanel("Secondtab", id = "second_tab",
sidebarLayout(
sidebarPanel(),
mainPanel()
)
),
tabPanel("Third tab", id = "third_tab",
sidebarLayout(
sidebarPanel(),
mainPanel()
)
)
)
))
server <- shinyServer(function(input, output, session) {
# disable tabs Exposure, Covariate, and Construct on page load
shinyjs::js$disableTab("Secondtab")
shinyjs::js$disableTab("Third tab")
})
# Run the application
shinyApp(ui = ui, server = server)
我认为您可以按照 和 shinyjs::disable()
的文档简化您的代码:
library(shiny)
library(shinyjs)
css <- "
.nav li a.disabled {
background-color: #aaa !important;
color: #333 !important;
cursor: not-allowed !important;
border-color: #aaa !important;
}"
ui <- shinyUI(fluidPage(
shinyjs::useShinyjs(),
shinyjs::inlineCSS(css),
navbarPage("Test",id="navbarPage",
tabPanel("FirstTab", id = "first_tab",
sidebarLayout(
sidebarPanel(),
mainPanel()
)
),
tabPanel("Secondtab", id = "second_tab",
sidebarLayout(
sidebarPanel(),
mainPanel()
)
),
tabPanel("Third tab", id = "third_tab",
sidebarLayout(
sidebarPanel(),
mainPanel()
)
)
)
))
server <- shinyServer(function(input, output, session) {
# disable tabs Exposure, Covariate, and Construct on page load
shinyjs::disable(selector = '.navbar-nav a[data-value="Secondtab"')
shinyjs::disable(selector = '.navbar-nav a[data-value="Third tab"')
})
# Run the application
shinyApp(ui = ui, server = server)
只是为了完成这个答案,获得 data-value
,在浏览器中打开应用程序,执行 Ctrl+Shift+C,将鼠标悬停在您想要的选项卡上,然后在检查器中检查其 data-value
参数。
我正在使用@SriPaladugu 提供的答案 here 来禁用 tabPanel()
并且我注意到如果 tabPanel(title,...)
中存在 space 它就不起作用.他们编写了自己的 JavaScript 代码并使用 shinyjs
到 enable/disable 面板,我不熟悉 JavaScript 代码来解决这个问题。他们执行此操作的代码存储在对象 jscode
中;如何修改代码以说明 tabPanel(title,...)
中的 space?
library(shiny)
library(shinyjs)
jscode <- "
shinyjs.disableTab = function(name) {
var tab = $('.nav li a[data-value=' + name + ']');
tab.bind('click.tab', function(e) {
e.preventDefault();
return false;
});
tab.addClass('disabled');
}
shinyjs.enableTab = function(name) {
var tab = $('.nav li a[data-value=' + name + ']');
tab.unbind('click.tab');
tab.removeClass('disabled');
}
"
css <- "
.nav li a.disabled {
background-color: #aaa !important;
color: #333 !important;
cursor: not-allowed !important;
border-color: #aaa !important;
}"
ui <- shinyUI(fluidPage(
shinyjs::useShinyjs(),
shinyjs::extendShinyjs(text = jscode, functions = c("disableTab","enableTab")),
shinyjs::inlineCSS(css),
navbarPage("Test",id="navbarPage",
tabPanel("FirstTab", id = "first_tab",
sidebarLayout(
sidebarPanel(),
mainPanel()
)
),
tabPanel("Secondtab", id = "second_tab",
sidebarLayout(
sidebarPanel(),
mainPanel()
)
),
tabPanel("Third tab", id = "third_tab",
sidebarLayout(
sidebarPanel(),
mainPanel()
)
)
)
))
server <- shinyServer(function(input, output, session) {
# disable tabs Exposure, Covariate, and Construct on page load
shinyjs::js$disableTab("Secondtab")
shinyjs::js$disableTab("Third tab")
})
# Run the application
shinyApp(ui = ui, server = server)
我认为您可以按照 shinyjs::disable()
的文档简化您的代码:
library(shiny)
library(shinyjs)
css <- "
.nav li a.disabled {
background-color: #aaa !important;
color: #333 !important;
cursor: not-allowed !important;
border-color: #aaa !important;
}"
ui <- shinyUI(fluidPage(
shinyjs::useShinyjs(),
shinyjs::inlineCSS(css),
navbarPage("Test",id="navbarPage",
tabPanel("FirstTab", id = "first_tab",
sidebarLayout(
sidebarPanel(),
mainPanel()
)
),
tabPanel("Secondtab", id = "second_tab",
sidebarLayout(
sidebarPanel(),
mainPanel()
)
),
tabPanel("Third tab", id = "third_tab",
sidebarLayout(
sidebarPanel(),
mainPanel()
)
)
)
))
server <- shinyServer(function(input, output, session) {
# disable tabs Exposure, Covariate, and Construct on page load
shinyjs::disable(selector = '.navbar-nav a[data-value="Secondtab"')
shinyjs::disable(selector = '.navbar-nav a[data-value="Third tab"')
})
# Run the application
shinyApp(ui = ui, server = server)
只是为了完成这个答案,获得 data-value
,在浏览器中打开应用程序,执行 Ctrl+Shift+C,将鼠标悬停在您想要的选项卡上,然后在检查器中检查其 data-value
参数。