我正在尝试创建一个仅将文本添加到 mainPanel 的应用程序。但是,添加文本时文本输出非常慢。
我想让这一切变得即时而快速,而不是花费太多时间。有没有办法让它在浏览器中处理而不是去R?
代码
library(shiny)
ui <- fluidPage(sidebarLayout(
sidebarPanel(textInput("text", label = NULL)),
mainPanel(textOutput("textout"))
))
server <- function(input, output, session) {
output$textout <- renderText({
input$text
})
}
shinyApp(ui, server)
Run Code Online (Sandbox Code Playgroud)
这是由于闪亮使用输入的方式造成的。在 javascript 中,它有一个 250 毫秒“去抖”选项,这解释了为什么它仅在您停止输入四分之一秒后才更新。
您可以覆盖它,但它似乎涉及编写 textInput 的替代品。关键的部分是 JavaScript 中的 getRatePolicy 函数。
library(shiny)
library(shinyCustom)
textinput_script <- "
<script>
var customTextInputBinding = $.extend({}, Shiny.inputBindings.bindingNames['shiny.textInput'].binding, {
find: function(scope) {
return $(scope).find('input.customTextInput');
},
subscribe: function(el, callback) {
$(el).on('keyup.customTextInputBinding input.customTextInputBinding', function(event) {
callback();
});
$(el).on('focusout.customTextInputBinding', function(event) { // on losing focus
callback();
});
},
unsubscribe: function(el) {
$(el).off('.customTextInputBinding');
},
getRatePolicy: function() {
return {
policy: 'direct'
};
}
});
Shiny.inputBindings.register(customTextInputBinding, 'shiny.customTextInput');
</script>
"
ui <- fluidPage(sidebarLayout(
sidebarPanel(
HTML(textinput_script),
customTextInput("text", label = NULL)
),
mainPanel(textOutput("textout"))
))
server <- function(input, output, session) {
output$textout <- renderText({
input$text
})
}
shinyApp(ui, server)
Run Code Online (Sandbox Code Playgroud)
这是从这里进行蚕食的,一般情况下执行此操作的实际指南在这里。
| 归档时间: |
|
| 查看次数: |
153 次 |
| 最近记录: |