首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >闪亮的jquery UI

闪亮的jquery UI
EN

Stack Overflow用户
提问于 2018-12-27 19:10:01
回答 1查看 2.5K关注 0票数 2

我想使用带有shiny的jquery UI (不使用shinyjqui库)。当我有一个层并试图使用jqueryUI移动它时,它工作得很好,但是当这个层是使用insertUI动态生成的时候,它就不起作用了。

代码如下:

代码语言:javascript
复制
library(shiny)

ui <- fluidPage(theme = "style.css",
            tags$script(src = "jquery-ui.js"),
            tags$script(src = "script2.js"),
            actionButton("add","Add layer"),
            div(class="aux"),
            div(id="works",style="width:300px;height:200px;background:red"))



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

    observeEvent(input$add,{
    insertUI(
      selector = ".aux",
      where="afterEnd",
      ui  = div(id=paste0("new",input$add),style="width:300px;height:200px;background:blue")

    )


  })






}
shinyApp(ui, server)

和js脚本

代码语言:javascript
复制
  $( function() {


    $("#works").draggable();
    $("#new1").draggable();


  });

谢谢!

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-12-27 20:40:17

这是因为#new1在启动时并不存在。您必须在创建javascript代码之后执行它,例如使用shinyjs::runjs。并在insertUI中使用immediate=TRUE

代码语言:javascript
复制
library(shiny)
library(shinyjs)

ui <- fluidPage(
  useShinyjs(),
  tags$head(
    tags$script(src = "jquery-ui/jquery-ui.min.js"),
    tags$script("$(function() {
                    $('#works').draggable();
                })")
  ),
  actionButton("add","Add layer"),
  div(class="aux"),
  div(id="works",style="width:300px;height:200px;background:red"))

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

  observeEvent(input$add,{
    insertUI(
      selector = ".aux",
      where="afterEnd",
      ui = div(id=paste0("new",input$add), style="width:300px;height:200px;background:blue"),
      immediate = TRUE
    )
    runjs("$('#new1').draggable();")
  })

}

shinyApp(ui, server)

票数 4
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/53944084

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档