- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试使用 intro.js 的 r 包装器突出显示我的 bsModal 的元素,但是无法让它工作。我也尝试过包含自定义 js 脚本,但我的 js 很糟糕。
我还设置了多个不同的测试,希望它能捕获某些东西,但似乎 intro.js 找不到模态的 div 或其中的任何元素。我正在使用 rintrojs
下面是一些人们让它在 javascript 中工作的例子:
但我个人对 Javascript 的了解还不够深,无法自己集成自定义解决方案。我已经试过了:(
这是我针对该问题托管的示例的链接: https://arun-sharma.shinyapps.io/introjs/
有谁知道如何让下面的虚拟示例工作?
library(rintrojs)
library(shiny)
library(shinydashboard)
intro_df <- data.frame(element = c('#plot_box', '#bttn2', '#box', '#modal'),
intro = c('test plot_box', 'test bttn2', 'test box', 'test modal'))
ui <- shinyUI(fluidPage(
introjsUI(),
mainPanel(
bsModal('modal', '', '', uiOutput('plot_box'), size = 'large'),
actionButton("bttn", "Start intro")
)))
server <- shinyServer(function(input, output, session) {
output$plot <- renderPlot({
plot(rnorm(50))
})
output$plot_box <- renderUI({
box(id = 'box',
actionButton('bttn2', 'dummy'),
plotOutput('plot'), width = '100%'
)
})
observeEvent(input$bttn,{
toggleModal(session, 'modal', toggle = 'toggle')
introjs(session, options = list(steps = intro_df))
})
})
shinyApp(ui = ui, server = server)
最佳答案
最终,我认为这个请求可以在 rintrojs
库中实现一些有用的功能。无论如何,您的问题有两个方面:
introjs
在模式在 HTML 中可用之前不应触发。最简单的方法是使用模式中的按钮来启动教程。如果您希望它是自动的,您将需要一些 JavaScript 来等待模态框准备就绪后再触发。introjs
想要使背景变灰并突出显示教程中的当前项目。这意味着它需要与模态 child “交错”。因为模态是它自己的堆栈上下文,所以需要从模态内部触发 introjs
以查看模态子项。如果您想查看整个 模态,那么从父级触发introjs
就足够了。这个功能似乎还没有在 rintrojs
包中,但是在 JavaScript 库中。为了完成#1,我添加了一个 JavaScript 函数来在模态加载时触发 introjs(在加载 HTML 元素的可配置延迟之后)。这需要 shinyjs
包。请注意 introJs(modal_id)
,这可确保教程在模态内触发。在纯 JavaScript 中,它将是 introJs('#modal')
:
run_introjs_on_modal_up <- function(
modal_id
, input_data
, wait
) {
runjs(
paste0(
"$('"
, modal_id
, "').on('shown.bs.modal', function(e) {
setTimeout(function(){
introJs('", modal_id, "').addSteps("
, jsonlite::toJSON(input_data, auto_unbox=TRUE)
, ").start()
}, ", wait, ")
})"
)
)
}
我还添加了一个简单的帮助程序,用于在离开模式时关闭 introjs
教程。
introjs_exit <- function(){
runjs("introJs().exit()")
}
还需要一行 CSS 来修复模态背景,以免过于急切并接管 DOM:
.modal-backdrop { z-index: -10;}
还有一个(大型/非最小)具有多个模态的工作示例。
library(rintrojs)
library(shiny)
library(shinydashboard)
library(shinyBS)
library(shinyjs)
intro_df <- data.frame(element = c('#plot_box', '#bttn2', '#box', '#modal'),
intro = c('test plot_box', 'test bttn2', 'test box', 'test modal'))
intro_df2 <- data.frame(element = c('#plot_box2'),
intro = c('test plot_box'))
run_introjs_on_modal_up <- function(
modal_id
, input_data
, wait
) {
runjs(
paste0(
"$('"
, modal_id
, "').on('shown.bs.modal', function(e) {
setTimeout(function(){
introJs('", modal_id, "').addSteps("
, jsonlite::toJSON(input_data, auto_unbox=TRUE)
, ").start()
}, ", wait, ")
})"
)
)
}
introjs_exit <- function(){
runjs("introJs().exit()")
}
ui <- shinyUI(fluidPage(
useShinyjs(),
tags$head(tags$style(".modal-backdrop { z-index: -10;}")),
introjsUI(),
mainPanel(
bsModal('modal', '', '', uiOutput('plot_box'), size = 'large'),
bsModal('modalblah', '', '', uiOutput('plot_box2'), size = 'large'),
actionButton("bttn", "Start intro")
)))
server <- shinyServer(function(input, output, session) {
output$plot <- renderPlot({
plot(rnorm(50))
})
output$plot2 <- renderPlot({
plot(rnorm(50))
})
output$plot_box <- renderUI({
box(id = 'box',
actionButton('bttn2', 'dummy'),
plotOutput('plot'), width = '100%'
)
})
output$plot_box2 <- renderUI({
box(id = 'box2',
plotOutput('plot2'), width = '100%'
)
})
run_introjs_on_modal_up("#modal",intro_df, 1000)
run_introjs_on_modal_up("#modalblah",intro_df2, 1000)
observeEvent(input$bttn,{
toggleModal(session, 'modal', toggle = 'toggle')
})
observeEvent(input$bttn2, {
toggleModal(session, 'modal', toggle = 'toggle')
introjs_exit()
toggleModal(session, 'modalblah', toggle = 'toggle')
})
})
shinyApp(ui = ui, server = server)
关于javascript - r 介绍 bsModal,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50997367/
我正在尝试使用 intro.js 的 r 包装器突出显示我的 bsModal 的元素,但是无法让它工作。我也尝试过包含自定义 js 脚本,但我的 js 很糟糕。 我还设置了多个不同的测试,希望它能捕获
我有一个场景,将数据保存到数据库后,我需要关闭 Bs-modal 弹出窗口,并且我的保存是在子组件中完成的,因此我传递了 Bs-modal code> 在子组件中使用 ()Input 并使用那里隐藏弹
我正在 bs-modal 中渲染一个表单,其中有一个包含 5 个项目的纸张选择。当我单击纸张选择时,下拉菜单出现在 bs-modal 后面,并且不可用。 我尝试为特定的纸张选择指定一个高的 z-ind
shiny 应用程序中的 bsModal 窗口带有默认的关闭 按钮。有没有办法可以禁用?我试图在 SO 上查找类似的问题,但没有找到符合我要求的问题。我认为,如果用户可以使用右上角的 X 按钮关闭窗口
我是一名优秀的程序员,十分优秀!