- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个 Shiny 的应用程序,我希望能够在其中编辑数据库中的数据。在我的应用程序中,我选择一个 ID 并检索相应的数据。 (在示例“记录”中)此数据被填充到不同的 Shiny 小部件中,以便能够对其进行编辑。 (在下面的“textID”和“remarksID”示例中)编辑并按下提交按钮后,数据库中的数据将更新。
这听起来并不复杂,使用普通 Shiny 小部件时也不是。但我正在使用一个特殊的手工输入小部件(灵感来自以下 SO 答案:How to create TextArea as input in a Shiny webapp in R?)。通过使用 javascript,我可以填写手工输入小部件。但是以某种方式它不会被识别为输入值,它只会在屏幕上可视化。编辑手工输入小部件时,它将被识别为输入值。
不过这似乎不是什么大问题。但是假设我不想更改手工输入值并且更改其他输入值并提交编辑。然后手工输入的值将变为空字符串。
下面 Shiny 的应用程序显示了这个问题。备注输入小部件的可视化输入默认是不可见的,只有在编辑的时候才会在结果中显示。 (这将被发送回数据库)
library(shiny)
library(shinyjs)
jsCode<-"shinyjs.FillRemarks = function(remarks){document.getElementById('remarksID').value = remarks}"
record <- structure(list(ID = "x1y2z3",
Country = "Netherlands",
Remarks = "Bla bla bla bla bla bla bla bla bla bla bla bla bla bla bla blabla bla bla bla bla"),
.Names = c("ID","Country", "Remarks"),
class = "data.frame", row.names = 1L)
ui <- shinyUI(fluidPage(mainPanel(
useShinyjs(),
extendShinyjs(text = jsCode),
fluidRow(
br(),
column(2,
selectInput("selectID",label = "Select ID:", choices = record$ID, selected = record$ID)
),
br(),br(),br(),hr()
),
fluidRow(
column(12,
textInput("textID",label = "Country:")
)
),
fluidRow(
column(3,
tags$p(id="remarksLabelID","Remarks:"),
tags$textarea(id="remarksID", rows=3, cols=40, "")
),
tags$style(type='text/css', "#remarksLabelID {
display: inline-block;
max-width: 100%;
margin-bottom: 5px;
font-weight: 700;
}"),
tags$style(type='text/css', "#remarksID {
resize: none;
width: 100%;
display: block;
padding: 6px 12px;
font-size: 14px;
line-height: 1.42857143;
color: #555;
background-color: #fff;
background-image: none;
border: 1px solid #ccc;
border-radius: 4px;
}")
),
fluidRow(
hr(),
column(12,
titlePanel("Preview"),
tableOutput("tableID")
)
)
)))
server <- function(input, output, session){
observeEvent(input$selectID,{
updateTextInput(session, "textID", label = "Country:", value = record$Country)
print(js$FillRemarks(record$Remarks))
})
observe({
outputTable <- structure(list(ID = record$ID,
Country = input$textID,
Remarks = input$remarksID),
row.names = 1L, class = "data.frame")
output$tableID <- renderTable({
outputTable
})
})
}
shinyApp(ui=ui, server=server)
我是接近解决方案还是我的思路错了?也想不出这个问题的好标题
最佳答案
我不完全确定我是否理解正确,但尽管我会尽力回答。
关于提交按钮,您必须考虑到当 submitButton 出现在 Shiny 应用程序中时,它会导致页面上的所有输入在按下按钮之前不会向服务器发送更新。也就是说,当您按下它时,所有输入都将被发送回服务器。在您的情况下,最好不要使用 submitButton,而是使用 actionButton,因为它允许更精细地控制哪些输入将触发代码的重新执行。
我已经修改了您的代码段,其中还包括一个操作按钮并附加了一行更新 remarksID 变量值的 javascript,因此它在您第一次运行时不为空。我想它现在可以如你所愿了。
你必须添加到 ui 的 JS 行是 jsCode2<-"shinyjs.updateRemarks = function(val){ Shiny.onInputChange('remarksID', val); }"
它将更新服务器上的 remarksID。它需要像这样完成,因为它是一个已经以编程方式修改的输入。为此感谢 Shiny 的 react 模型。
然后:
extendShinyjs(text = jsCode),
extendShinyjs(text = jsCode2),
在 server.R 中你必须在这里使用它:
updateTextInput(session, "textID", label = "Country:", value = record$Country)
js$updateRemarks(record$Remarks)
js$FillRemarks(record$Remarks)
最后,您还必须将其添加到 server.R 才能使用操作按钮。
observeEvent(input$button, {
print(input$selectID)
print(input$textID)
print(input$remarksID)
})
完整的片段是:
服务器.R
library(shiny)
library(shinyjs)
record <- structure(list(ID = "x1y2z3",
Country = "Netherlands",
Remarks = "Bla bla bla bla bla bla bla bla bla bla bla"),
.Names = c("ID","Country", "Remarks"),
class = "data.frame", row.names = 1L)
server <- function(input, output, session){
observeEvent(input$selectID,{
updateTextInput(session, "textID", label = "Country:", value = record$Country)
js$updateRemarks(record$Remarks)
js$FillRemarks(record$Remarks)
})
observeEvent(input$button, {
print(input$selectID)
print(input$textID)
print(input$remarksID)
})
observe({
outputTable <- structure(list(ID = record$ID,
Country = input$textID,
Remarks = input$remarksID),
row.names = 1L, class = "data.frame")
output$tableID <- renderTable({outputTable})
})
}
ui.R
jsCode<-"shinyjs.FillRemarks = function(remarks){document.getElementById('remarksID').value = remarks}"
jsCode2<-"shinyjs.updateRemarks = function(val){ Shiny.onInputChange('remarksID', val); }"
record <- structure(list(ID = "x1y2z3",
Country = "Netherlands",
Remarks = "Bla bla bla bla bla bla bla bla bla bla bla"),
.Names = c("ID","Country", "Remarks"),
class = "data.frame", row.names = 1L)
ui <- shinyUI(fluidPage(mainPanel(
useShinyjs(),
extendShinyjs(text = jsCode),
extendShinyjs(text = jsCode2),
fluidRow(
br(),
column(2, selectInput("selectID",label = "Select ID:", choices = record$ID, selected = record$ID)),
br(),br(),br(),hr()
),
fluidRow( column(12, textInput("textID",label = "Country:") ) ),
fluidRow( column(3, tags$p(id="remarksLabelID","Remarks:"), tags$textarea(id="remarksID", rows=3, cols=40, "") ),
tags$style(type='text/css', "#remarksLabelID {
display: inline-block;
max-width: 100%;
margin-bottom: 5px;
font-weight: 700;
}"),
tags$style(type='text/css', "#remarksID {
resize: none;
width: 100%;
display: block;
padding: 6px 12px;
font-size: 14px;
line-height: 1.42857143;
color: #555;
background-color: #fff;
background-image: none;
border: 1px solid #ccc;
border-radius: 4px;
}")
),
fluidRow( actionButton("button", "An action button")),
fluidRow(
hr(),
column(12,
titlePanel("Preview"),
tableOutput("tableID")
)
)
)))
关于javascript - 默认情况下, Shiny 的应用程序数据对于特殊输入小部件不可见,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37791624/
我是 Java 新手,这是我的代码, if( a.name == b.name && a.displayname == b.displayname && a.linknam
在下面的场景中,我有一个 bool 值。根据结果,我调用完全相同的函数,唯一的区别是参数的数量。 var myBoolean = ... if (myBoolean) { retrieve
我是一名研究 C++ 的 C 开发人员: 我是否正确理解如果我抛出异常然后堆栈将展开直到找到第一个异常处理程序?是否可以在不展开的情况下在任何 throw 上打开调试器(即不离开声明它的范围或任何更高
在修复庞大代码库中的错误时,我观察到一个奇怪的情况,其中引用的动态类型从原始 Derived 类型更改为 Base 类型!我提供了最少的代码来解释问题: struct Base { // some
我正在尝试用 C# 扩展给定的代码,但由于缺乏编程经验,我有点陷入困境。 使用 Visual Studio 社区,我尝试通过控制台读出 CPU 核心温度。该代码使用开关/外壳来查找传感器的特定名称(即
这可能是一个哲学问题。 假设您正在向页面发出 AJAX 请求(这是使用 Prototype): new Ajax.Request('target.asp', { method:"post", pa
我有以下 HTML 代码,我无法在所有浏览器中正常工作: 我试图在移动到
我对 Swift 很陌生。我如何从 addPin 函数中检索注释并能够在我的 addLocation 操作 (buttonPressed) 中使用它。我正在尝试使用压力触摸在 map 上添加图钉,在两
我设置了一个详细 View ,我是否有几个 Nib 文件根据在 Root View Controller 的表中选择的项目来加载。 我发现,对于 Nibs 的类,永远不会调用 viewDidUnloa
我需要动态访问 json 文件并使用以下代码。在本例中,“bpicsel”和“temp”是变量。最终结果类似于“data[0].extit1” var title="data["+bpicsel+"]
我需要使用第三方 WCF 服务。我已经在我的证书存储中配置了所需的证书,但是在调用 WCF 服务时出现以下异常。 向 https://XXXX.com/AHSharedServices/Custome
在几个 SO 答案(1、2)中,建议如果存在冲突则不应触发 INSERT 触发器,ON CONFLICT DO NOTHING 在触发语句中。也许我理解错了,但在我的实验中似乎并非如此。 这是我的 S
如果进行修改,则会给出org.hibernate.NonUniqueObjectException。在我的 BidderBO 类(class)中 @Override @Transactional(pr
我使用 indexOf() 方法来精细地查找数组中的对象。 直到此刻我查了一些资料,发现代码应该无法正常工作。 我在reducer中尝试了上面的代码,它成功了 let tmp = state.find
假设我有以下表格: CREATE TABLE Game ( GameID INT UNSIGNED NOT NULL, GameType TINYINT UNSIGNED NOT NU
代码: Alamofire.request(URL(string: imageUrl)!).downloadProgress(closure: { (progress) in
我是一名优秀的程序员,十分优秀!