有了上一個部分的作業,充分的執行了前端UI的輸入,後端Server運算,與前端UI的再顯示結果功能.
本段,將就前後端往返的Action部分,進行進階的程式控制.
1. Reactivity in R
Reactiveity 流程
以前篇的例子來看,透過畫面的拉bar拉動,基本上就是使用者自UI給了新的Input,這時即透過Reactivity Notify傳遞給Server進行運算,運算完畢之後,再回應給UI進行顯示。
兩段的流程Step圖示如下:
data:image/s3,"s3://crabby-images/29c22/29c22467100aa96e61c5d7968a6a94bb887c4d7f" alt="https://ithelp.ithome.com.tw/upload/images/20180110/20107033GOTQndejXE.png"
Reactiveity值傳遞
Reactiveity Values的傳遞,重點如下:
- Reactive values act as the data streams that flow through your app.
- The input list is a list of reactive values. Thevalues show the current state of the inputs.
- You can only call a reactive value from a function that is designed to work with one.
- Reactive values notify. The objects created by reactive functions respond.
基本流程(即時互動)
data:image/s3,"s3://crabby-images/49b02/49b02f18870bcb4512fe488eebc589c92415dff7" alt="https://ithelp.ithome.com.tw/upload/images/20180110/201070338tlfEw8mwM.png"
可透過處理,有不同的互動方式(即時/人工(延時)觸發)
2.reactive()函數相關模組化作業
首先先來看看這段作業
# 02-two-outputs
library(shiny)
ui <- fluidPage(
sliderInput(inputId = "num",
label = "Choose a number",
value = 25, min = 1, max = 100),
plotOutput("hist"),
verbatimTextOutput("stats")
)
server <- function(input, output) {
output$hist <- renderPlot({
hist(rnorm(input$num))
})
output$stats <- renderPrint({
summary(rnorm(input$num))
})
}
shinyApp(ui = ui, server = server)
本段程式是一個簡易的案例,可以看見一個input$num,將對應有兩組輸出:
- rutput$hist <- renderPlot
- output$stats <- renderPrint
而根據下圖的流程說明,input$num這個為共用的物件在傳遞。
data:image/s3,"s3://crabby-images/49ffa/49ffa28b6cef010ae4f4d1daca3733b98647f93b" alt="https://ithelp.ithome.com.tw/upload/images/20180110/20107033qbI1qMO5Z1.png"
這類共用的物件,將可透過reactive()函數,將這類共用的部份抽出當作共用的模組的部分。
(例:data <- reactive({rnorm(input$num)}))
data:image/s3,"s3://crabby-images/0f8a7/0f8a75ffd96824000119a8a76cd4c47d32884eae" alt="https://ithelp.ithome.com.tw/upload/images/20180107/20107033Jea7QEtrQm.png"
reactive() 重點提示:
- reactive() makes an object to use (indownstream code)
- Reactive expressions are themselves reactive. Use them to modularize your apps.
- Call a reactive expression like a function
- Reactive expressions cache their values to avoid unnecessary computation
2. Trigger Code
Prevent reactions with isolate()
data:image/s3,"s3://crabby-images/7794c/7794c84ee8ae82a4b9c0d8835f0281abcd9802b8" alt="https://ithelp.ithome.com.tw/upload/images/20180110/20107033D136gSCe4f.png"
重點提示
- isolate() makes an non-reactive object
- Use isolate() to treat reactive values like normal R values
Trigger code with observeEvent() / observe()
data:image/s3,"s3://crabby-images/d0d97/d0d9784add3d5c0b2dd3bd4d976fde016b1397f8" alt="https://ithelp.ithome.com.tw/upload/images/20180110/20107033S23l867EBk.png"
重點提示
- observeEvent() triggers code to run on the server
- Specify precisely which reactive values should invalidate the observer
- Use observe() for a more implicit syntax
Delay reactions with eventReactive()
重點提示
- Use eventReactive() to delay reactions
- eventReactive() creates a reactive expression
- You can specify precisely which reactive values should invalidate the expression
Manage state with reactiveValues()
data:image/s3,"s3://crabby-images/4b86f/4b86f45b0106808e2a5ea2da1c813f788681f5ac" alt="https://ithelp.ithome.com.tw/upload/images/20180110/20107033aH64P7naaO.png"
data:image/s3,"s3://crabby-images/e1a1f/e1a1f238af6aff590bd6ff346fd4646ad03dc331" alt="https://ithelp.ithome.com.tw/upload/images/20180110/20107033O227ShrCWy.png"
data:image/s3,"s3://crabby-images/091a2/091a2e09e46458ab969a7d6191fc70480db5589c" alt="https://ithelp.ithome.com.tw/upload/images/20180110/20107033O8bLs4hiJK.png"
data:image/s3,"s3://crabby-images/3f490/3f49093ca84c7e6905db1e68df5ca50f50cc64ff" alt="https://ithelp.ithome.com.tw/upload/images/20180110/20107033LumfQrGHb3.png"
data:image/s3,"s3://crabby-images/2f329/2f329ed98707292f193e371b42f3e393cbc8bffe" alt="https://ithelp.ithome.com.tw/upload/images/20180110/20107033VHsKyTbJXi.png"
重點提示
- reactiveValues() creates a list of reactive values
- You can manipulate these values (usually with observeEvent())
小結
## Parting tips(非常重要!!!)
首先先看一下Shiny APP整個的架構。
data:image/s3,"s3://crabby-images/dab60/dab60e778ff8d7ee82d998894c048b49a9696ab9" alt="https://ithelp.ithome.com.tw/upload/images/20180110/20107033tFcrWnt9Ef.png"
呼應前圖對應層級,有些的作業處理,就效能面是或是生效的範圍來說,就要放到對應的地方處理。舉例來說,在Server範圍以外的程式,將只被執行一次,某些特殊的初始作業,例如讀檔案存成df的作業,就是初始時,僅需處理一次的作業。
data:image/s3,"s3://crabby-images/a3b3b/a3b3b4e1d27782287dc16d668b4c057f387d1f81" alt="https://ithelp.ithome.com.tw/upload/images/20180110/20107033mw69x6IJpv.png"
參考資料
How to start with Shiny – Part 2
[shiny-cheatsheet copy - RStudio](shiny-cheatsheet copy - RStudio)