Vartotojo patirties gerinimas naudojant skirtukų pastovumą blizgančiose informacijos suvestinėse
Įsivaizduokite, kad dirbate sudėtingoje informacijos suvestinėje, kurioje keli skirtukų rinkiniai vadovauja jūsų darbo eigai. Perjungimas tarp skirtukų rinkinių dažnai iš naujo nustato pažangą, todėl verčiamas grįžti į paskutinį skirtuką, su kuriuo dirbote. Tai gali būti nelinksma ir atimti daug laiko, ypač kai dirbama su dideliais duomenų rinkiniais arba sudėtinga analize. 🚀
Blizgančiose informacijos suvestinėse, sukurtose naudojant bs4Dash, paskutinio aktyvaus skirtuko išsaugojimas pereinant tarp skirtukų rinkinių yra dažnas iššūkis. Vartotojai nori sklandžiai naudotis patirtimi, kai grįžę į skirtukų rinkinį jie grįžta į ankstesnę būseną. Nors egzistuoja rankiniai sprendimai, jie gali būti sudėtingi ir neveiksmingi kūrėjams ir vartotojams.
Norint išspręsti šią problemą, pradedamas naudoti dinaminis skirtukų išlikimas naudojant „shinyjs“ ir tinkintą „JavaScript“ integravimą. Naudodami reaktyviąsias reikšmes ir įvykių tvarkymą, galite sukurti prietaisų skydelį, kuris įsimena paskutinį aplankytą skirtuką kiekviename skirtukų rinkinyje, taip padidindami vartotojų pasitenkinimą ir našumą.
Šiame straipsnyje mes išnagrinėsime, kaip efektyviai įdiegti šią funkciją. Aptarsime kodo fragmentus, pagrindines sąvokas ir praktinius patarimus, kaip išlaikyti skirtukų būsenas bs4Dash. Pasinerkime ir kurkime prietaisų skydelius, kurie naudotojams atrodytų protingesni ir intuityvesni! 💡
komandą | Naudojimo pavyzdys |
---|---|
reactiveValues | Ši komanda sukuria reaktyvųjį sąrašą, kuriame saugomas paskutinis aplankytas kiekvieno skirtukų rinkinio skirtukas. Tai leidžia išlaikyti būseną naudotojo sąveikos metu, užtikrinant, kad programa atsimintų, kuris skirtukas buvo aktyvus kiekviename skirtukų rinkinyje. |
shinyjs::onclick | Naudojamas „JavaScript“ paspaudimų įvykiams susieti su R kodu. Šiame kontekste jis perjungia aktyvų skirtukų rinkinį pagal vartotojo paspaudimus ir atitinkamai atnaujina įvesties reikšmes. |
req | Blizganti funkcija, patvirtinanti, ar įvesties arba reaktyviosios reikšmės nėra . Jis naudojamas siekiant užtikrinti, kad skirtukų rinkinio būsena būtų pasiekiama prieš ją pateikiant arba apdorojant. |
bs4SidebarMenu | Sugeneruoja dinaminį šoninės juostos meniu, būdingą aktyviam skirtukų rinkiniui. Taip užtikrinama, kad naudotojai matys tik meniu parinktis, susijusias su pasirinktu skirtukų rinkiniu. |
session$sendCustomMessage | Įgalina ryšį tarp R serverio ir „JavaScript“ kliento pusėje. Jis naudojamas dinamiškai paryškinti paskutinį aktyvų skirtuką, kai vartotojas perjungia skirtukų rinkinius. |
Shiny.addCustomMessageHandler | Apibrėžia tinkintą „JavaScript“ pranešimų tvarkyklę, kad būtų galima apdoroti komandas iš R serverio. Šiame pavyzdyje jis klauso komandos perjungti skirtukus ir atlieka būtinus veiksmus kliento naršyklėje. |
setTimeout | „JavaScript“ funkcija, naudojama tam tikro kodo vykdymui atidėti. Čia jis naudojamas trumpai palaukti prieš nustatant aktyvaus skirtuko įvesties reikšmę, kad būtų užtikrinta, jog vartotojo sąsaja yra paruošta. |
$(document).on('shiny:connected') | „JavaScript“ įvykių klausytojas suaktyvinamas, kai „Shiny“ programa yra visiškai prijungta. Jis inicijuoja programos būseną nustatydamas numatytąjį aktyvų skirtukų rinkinį, kai programa įkeliama. |
bs4TabItems | Apibrėžia kelis skirtukų elementus skirtukų rinkinyje. Kiekvienas elementas atitinka konkrečią turinio sritį, todėl programos išdėstymas atitinka vartotojo sąveikos reikalavimus. |
observeEvent | Stebi ir reaguoja į konkrečios reaktyviosios vertės arba įvesties pokyčius. Jis naudojamas dinamiškai atnaujinti skirtukų būsenas ir sinchronizuoti serverį su vartotojo sąsaja. |
Sumanesnės navigacijos kūrimas naudojant skirtukų pastovumą programoje bs4Dash
Pateiktas scenarijus sprendžia dažną prietaisų skydelių problemą: paskutinio aktyvaus skirtuko išlaikymas perjungiant kelis skirtukų rinkinius. Tai ypač svarbu prietaisų skydeliams su sudėtingomis darbo eigomis, kuriose naudotojai turi grįžti į ankstesnį kontekstą. Naudodamas reaktyviąsias reikšmes ir shinyjs, scenarijus užtikrina, kad aktyvaus skirtuko būsena būtų dinamiškai išsaugoma ir nuskaitoma, o tai pagerina naudotojo patirtį. Pagrindinis mechanizmas apima paskutinio aktyvaus kiekvieno skirtukų rinkinio skirtuko stebėjimą ir jo atnaujinimą, kai įvyksta pakeitimų. Šis įgyvendinimas taip pat naudoja tinkintą „JavaScript“, kad būtų užtikrinta sklandi kliento ir serverio sąveika, parodydama R derinimo su priekiniais įrankiais galią. 🌟
Kai vartotojas sąveikauja su skirtukų rinkiniu, „JavaScript“ tvarkyklė siunčia aktyvaus skirtuko informaciją atgal į „Shiny“ serverį per „shinyjs::onclick“. Tai suaktyvina atnaujinimus objekte „reactiveValues“, kuriame saugoma kiekvieno skirtukų rinkinio būsena. Pavyzdžiui, jei vartotojas spusteli „1 skirtukų rinkinys“, to skirtukų rinkinio būsena išsaugoma kaip „tab1_1“ arba „tab1_2“. Dinamiškai pateikiamas šoninės juostos meniu taip pat pritaikomas pagal pasirinktą skirtukų rinkinį, užtikrinant, kad būtų rodomos tik atitinkamos parinktys. Šis dizainas optimizuoja vizualinį išdėstymą ir funkcionalumą, todėl sąsaja yra intuityvi ir reaguoja. 🖥️
Funkcija „session$sendCustomMessage“ čia yra labai svarbi. Tai leidžia serveriui susisiekti su kliento „JavaScript“, kad vėl suaktyvintų paskutinį aplankytą skirtuką, kai grįžtama prie skirtukų rinkinio. Pavyzdžiui, jei vartotojas pereina į „2 skirtukų rinkinį“ ir vėliau grįžta į „1 skirtukų rinkinį“, programa automatiškai atkurs paskutinį aktyvų skirtuką „1 skirtukų rinkinys“. Tai pašalina rankinio naršymo poreikį, todėl naudotojai sutaupo laiko ir pastangų. „Req“ naudojimas užtikrina, kad visi veiksmai būtų atliekami tik tada, kai įvykdomos reikiamos sąlygos, taip išvengiama nereikalingų klaidų.
Apskritai šis scenarijus demonstruoja sklandų R užpakalinės dalies integravimą su dinaminėmis priekinės dalies funkcijomis. Naudodami bs4Dash, Shiny ir `shinyjs', kūrėjai gali sukurti prietaisų skydelius, kurie būtų ne tik estetiški, bet ir išmanesni naudojimo požiūriu. Įsivaizduokite, kad prietaisų skydelyje dirbate su išsamia ataskaita ir kiekvieną kartą, kai perjungiate skirtukus, jūsų pažanga vyksta ten, kur palikote. Šis metodas sumažina nusivylimą ir užtikrina sklandesnę darbo eigą. „R“ ir „JavaScript“ elementų įtraukimas parodo, kaip įvairūs įrankiai gali veikti kartu veiksmingai išspręsti realaus pasaulio iššūkius. 💡
Kaip išsaugoti paskutinį aktyvų skirtuką kelių skirtukų rinkinio bs4Dash sąrankoje?
Naudojant R su Shiny framework ir bs4Dash biblioteka dinamiškai įsiminti aktyvius skirtukus.
# Import necessary libraries
library(shiny)
library(bs4Dash)
library(shinyjs)
# Define the UI
ui <- bs4DashPage(
header = bs4DashNavbar(title = "Remember Last Tab in bs4Dash"),
sidebar = bs4DashSidebar(uiOutput("sidebar_menu")),
body = bs4DashBody(
useShinyjs(),
bs4TabItems(
bs4TabItem(tabName = "tab1_1", h2("Content for Tab 1.1"))
bs4TabItem(tabName = "tab1_2", h2("Content for Tab 1.2"))
)
)
)
# Define the server
server <- function(input, output, session) {
lastTabs <- reactiveValues(tabset1 = "tab1_1")
output$sidebar_menu <- renderUI({
bs4SidebarMenu(
id = "sidebar",
bs4SidebarMenuItem("Tab 1.1", tabName = "tab1_1", icon = icon("dashboard"))
)
})
observeEvent(input$sidebar, {
lastTabs$tabset1 <- input$sidebar
})
}
# Run the app
shinyApp(ui, server)
Alternatyvus metodas: „JavaScript“ integravimas, kad skirtukų valdymas būtų sklandesnis
Šis metodas apima tinkintų „JavaScript“ tvarkyklių naudojimą kartu su R ir bs4Dash, kad būtų optimizuota sąveika.
library(shiny)
library(bs4Dash)
library(shinyjs)
ui <- bs4DashPage(
header = bs4DashNavbar(title = "Remember Last Tab in bs4Dash"),
sidebar = bs4DashSidebar(uiOutput("sidebar_menu")),
body = bs4DashBody(
useShinyjs(),
tags$script(HTML("
$(document).on('shiny:connected', function (event) {
Shiny.setInputValue('activeTabSet', 'tabset1')
})
")),
bs4TabItems(
bs4TabItem(tabName = "tab1_1", h2("Content for Tab 1.1"))
)
)
)
server <- function(input, output, session) {
output$sidebar_menu <- renderUI({
req(input$activeTabSet)
if (input$activeTabSet == "tabset1") {
bs4SidebarMenu(
id = "sidebar",
bs4SidebarMenuItem("Tab 1.1", tabName = "tab1_1", icon = icon("dashboard"))
)
}
})
}
shinyApp(ui, server)
„bs4Dash“ skirtukų valdymo optimizavimas naudotojo patogumui
Vienas iš labiausiai neįvertintų efektyvių prietaisų skydelių kūrimo aspektų yra atsižvelgti į vartotojo sąveikos srautą. Informacijos suvestinėse, sukurtose naudojant bs4Dash, kelių skirtukų rinkinių tvarkymas gali būti sudėtingas, jei naudotojai perjungdami skirtukus praranda kontekstą. Čia įdiegiamas mechanizmas, skirtas prisiminti paskutinis aktyvus skirtukas šviečia. Tai supaprastina darbo eigą ir sumažina trintį, ypač sudėtingose programose, kurios atlieka duomenų tyrinėjimo ar administravimo užduotis. 🚀
Ši koncepcija gali būti išplėsta ne tik išlaikant paskutinį aktyvų skirtuką, bet ir valdant pasirinktinius vartotojo sąsajos elementus. Pavyzdžiui, susieję skirtukų patvarumą su dinaminiu filtravimu, vartotojai gali grįžti ir į pageidaujamą skirtuką, ir į anksčiau nustatytus filtrus. Šis derinys gali žymiai pagerinti naudojimo patogumą, todėl prietaisų skydeliai bus labiau orientuoti į vartotoją. Kitas pastebimas pranašumas yra tai, kad ji pagerina našumą, nes išvengiama perteklinių serverio skambučių, nes programa gali numatyti, kur vartotojas eis toliau.
Be to, pridėjus animaciją ar vaizdinius ženklus perkeliant skirtukus galima dar labiau pagerinti vartotojo patirtį. Subtilių paryškinimų naudojimas norint nurodyti paskutinį aplankytą skirtuką arba sklandaus slinkimo efektas perjungiant skirtukus yra pavyzdžiai, kaip padaryti programą patobulintą ir intuityvią. Kūrėjai gali panaudoti bibliotekas, pvz., „shinyjs“, kad šiuos patobulinimus sklandžiai integruotų į Blizgias prietaisų skydelius, užtikrinant subalansuotą funkcionalumo ir estetikos derinį. 🌟
Dažni klausimai apie bs4Dash skirtukų rinkinių tvarkymą
- Kaip dinamiškai atnaujinti šoninės juostos meniu pagal aktyvų skirtukų rinkinį?
- Galite naudoti renderUI funkcija sąlygiškai pateikti šoninės juostos meniu pagal input$activeTabSet vertė.
- Ar galiu išsaugoti ne tik paskutinę aktyvaus skirtuko būseną?
- Taip, naudojant reactiveValues, galite saugoti papildomą informaciją, pvz., filtrus, vartotojo pasirinkimus ar kitas būsenas.
- Ką daryti, jei vartotojas uždaro prietaisų skydelį ir vėl atidaro? Ar galima prisiminti jų būseną?
- Norėdami išlaikyti būseną per seansus, galite naudoti shinyStore paketą arba duomenų bazę, kad išsaugotumėte ir gautumėte konkrečius vartotojo nustatymus.
- Kaip padaryti, kad skirtukų perėjimai būtų sklandesni?
- Pasinaudokite shinyjs biblioteką, kad pridėtumėte tinkintą „JavaScript“, skirtą animacijai arba uždelstam skirtukų perėjimui.
- Ar galima suaktyvinti serverio veiksmus pagal skirtukų pakeitimus?
- Taip, galite naudoti observeEvent funkcija vykdyti serverio logiką, kai pasikeičia aktyvus skirtukas.
Skirtukų naršymo supaprastinimas, siekiant geresnių prietaisų skydelių
Užtikrinti, kad prietaisų skydeliai atsimintų paskutinį aktyvų vartotojo skirtuką, yra svarbus žingsnis kuriant intuityvią ir efektyvią sąsają. Sujungę R reaktyviąsias galimybes su JavaScript, kūrėjai gali užtikrinti sklandesnę ir išmanesnę naršymo patirtį, todėl jų programos išsiskirtų. 🌟
Skirtukų patvarumo integravimas taupo naudotojų laiką ir padeda išlaikyti darbo eigos tęstinumą, net ir atliekant sudėtingas sąrankas. Šis metodas pabrėžia, kaip svarbu teikti pirmenybę naudotojo sąveikai kuriant prietaisų skydelį, kad kiekvienas paspaudimas būtų prasmingas ir produktyvus. Su tokiais įrankiais kaip bs4Dash ir shinyjs sukurti išmaniąsias programas dar niekada nebuvo taip paprasta.
Šaltiniai ir nuorodos
- Šis straipsnis buvo įkvėptas oficialios bs4Dash dokumentacijos. Norėdami gauti daugiau informacijos, apsilankykite bs4Dash dokumentacija .
- Papildomi pavyzdžiai ir paaiškinimai buvo pritaikyti iš Shiny R bibliotekos išteklių, esančių adresu Shiny R oficiali svetainė .
- „JavaScript“ integravimo su „Shiny“ gairės buvo pateiktos „shinyjs“ paketo dokumentacijoje adresu shinyjs Dokumentacija .
- Apie tinkintas JavaScript ir vartotojo sąsajos sąveikos strategijas buvo pranešta bendruomenės diskusijose apie RStudio bendruomenė .