我的问题类似于Shiny how to block the user from accessing a tab?

但我需要的是:

library(shiny)

ui <- shinyUI(navbarPage(
  "",
  tabPanel(
    h1("Tab1"), 
    value = "nav1",
    mainPanel(
      br(),
      h2("The user must press this button to access the other tab."),
      br(),
      shiny::actionButton('button', 'press the button', onclick = "$(tab).removeClass('disabled')")
    )
  ),
  tabPanel(
    h1("Tab2"),
    value = "nav2",
    uiOutput("tab2contents")
  ),
  tags$script(
    '
    var tab = $(\'a[data-value="nav2"]\').parent().addClass("disabled");
    $(function(){
      $(tab.parent()).on("click", "li.disabled", function(e) {
        e.preventDefault();
        return false;
      });
    });
    '
  )
))    

server <- shinyServer(function(input, output) {

})

# Run the application
shinyApp(ui = ui, server = server)

在上面的代码中,除非单击按钮,否则第二个选项卡将被阻止,但如何进一步更新此选项卡,以便在单击按钮后,用户将自动转到第二个选项卡?

推荐答案

既然你把tabPanel放在navbarPage里,你就必须用updateNavbarPage.你需要给navbarPage分和id分.

library(shiny)

ui <- shinyUI(navbarPage(
  "", id = "mainpage",
  tabPanel(
    h1("Tab1"), 
    value = "nav1",
    mainPanel(
      br(),
      h2("The user must press this button to access the other tab."),
      br(),
      shiny::actionButton('button', 'press the button', onclick = "$(tab).removeClass('disabled')")
    )
  ),
  tabPanel(
    h1("Tab2"),
    value = "nav2",
    uiOutput("tab2contents")
  ),
  tags$script(
    '
    var tab = $(\'a[data-value="nav2"]\').parent().addClass("disabled");
    $(function(){
      $(tab.parent()).on("click", "li.disabled", function(e) {
        e.preventDefault();
        return false;
      });
    });
    '
  )
))    

server <- shinyServer(function(input, output) {
  observeEvent(input$button,
               {
                 updateNavbarPage(inputId = "mainpage", selected = "nav2")
               }, ignoreInit = TRUE)
})

# Run the application
shinyApp(ui = ui, server = server)

Javascript相关问答推荐

在分区内迭代分区

vanillajs-datepicker未设置输入值,日期单击时未触发更改事件

对象和数字减法会抵消浏览器js中的数字

类型自定义lazy Promise. all

扫描qr code后出错whatter—web.js

如何修复(或忽略)HTML模板中的TypeScript错误?'

有没有可能使滑动img动画以更快的速度连续?

更改JSON中使用AJAX返回的图像的路径

屏幕右侧屏障上的产卵点""

Chart.js 4.4.2,当悬停在一个数据点上时,如何在工具提示中拥有多个数据点/标签?

保持物品顺序的可变大小物品分配到平衡组的算法

我在Django中的视图中遇到多值键错误

如何将多维数组插入到另一个多维数组中?

以Angular 实现ng-Circle-Progress时出错:模块没有导出的成员

如何创建返回不带`new`关键字的实例的类

如何将数据块添加到d3力有向图中?

在表单集中保存更改时删除';禁用';

如何使本地html页面在重新加载时保持当前可隐藏部分的打开状态?

如何在Highlihte.js代码区旁边添加行号?

如何调整下拉内容,使其不与其他元素重叠?