Learn R Programming

shiny

Easily build rich and productive interactive web apps in R — no HTML/CSS/JavaScript required.

Features

  • An intuitive and extensible reactive programming model which makes it easy to transform existing R code into a "live app" where outputs automatically react to new user input.
    • Compared to event-based programming, reactivity allows Shiny to do the minimum amount of work when input(s) change, and allows humans to more easily reason about complex MVC logic.
  • A prebuilt set of highly sophisticated, customizable, and easy-to-use widgets (e.g., plots, tables, sliders, dropdowns, date pickers, and more).
  • An attractive default look based on Bootstrap which can also be easily customized with the bslib package or avoided entirely with more direct R bindings to HTML/CSS/JavaScript.
  • Seamless integration with R Markdown, making it easy to embed numerous applications natively within a larger dynamic document.
  • Tools for improving and monitoring performance, including native support for async programming, caching, load testing, and more.
  • Modules: a framework for reducing code duplication and complexity.
  • An ability to bookmark application state and/or generate code to reproduce output(s).
  • A rich ecosystem of extension packages for more custom widgets, input validation, unit testing, and more.

Installation

To install the stable version from CRAN:

install.packages("shiny")

Getting Started

Once installed, load the library and run an example:

library(shiny)
# Launches an app, with the app's source code included
runExample("06_tabsets")
# Lists more prepackaged examples
runExample()

For more examples and inspiration, check out the Shiny User Gallery.

For help with learning fundamental Shiny programming concepts, check out the Mastering Shiny book and the Shiny Tutorial. The former is currently more up-to-date with modern Shiny features, whereas the latter takes a deeper, more visual, dive into fundamental concepts.

Join the conversation

If you want to chat about Shiny, meet other developers, or help us decide what to work on next, join us on Discord.

Getting Help

To ask a question about Shiny, please use the RStudio Community website.

For bug reports, please use the issue tracker and also keep in mind that by writing a good bug report, you're more likely to get help with your problem.

Contributing

We welcome contributions to the shiny package. Please see our CONTRIBUTING.md file for detailed guidelines of how to contribute.

License

The shiny package as a whole is licensed under the GPLv3. See the LICENSE file for more details.

R version support

Shiny is supported on the latest release version of R, as well as the previous four minor release versions of R. For example, if the latest release R version is 4.1, then that version is supported, as well as 4.0, 3.6, 3.5, and 3.4.

Copy Link

Version

Install

install.packages('shiny')

Monthly Downloads

457,663

Version

1.10.0

License

GPL-3 | file LICENSE

Issues

Pull Requests

Stars

Forks

Maintainer

Winston Chang

Last Published

December 14th, 2024

Functions in shiny (1.10.0)

bookmarkButton

Create a button for bookmarking/sharing
ExtendedTask

Task or computation that proceeds in the background
applyInputHandlers

Apply input handlers to raw input values
actionButton

Action button/link
clickOpts

Control interactive plot point events
brushOpts

Create an object representing brushing options
bootstrapLib

Bootstrap libraries
MockShinySession

Mock Shiny Session
bootstrapPage

Create a Bootstrap page
brushedPoints

Find rows of data selected on an interactive plot.
checkboxGroupInput

Checkbox Group Input Control
busyIndicatorOptions

Customize busy indicator options
checkboxInput

Checkbox Input Control
column

Create a column within a UI definition
callModule

Invoke a Shiny module
dateRangeInput

Create date range input
devmode

Shiny Developer Mode
diskCache

Create disk cache (deprecated)
createWebDependency

Create a web dependency
debounce

Slow down a reactive expression with debounce/throttle
createRenderFunction

Implement custom render functions
conditionalPanel

Conditional Panel
domains

Reactive domains
downloadButton

Create a download button or link
dateInput

Create date input
enableBookmarking

Enable bookmarking for a Shiny application
exportTestValues

Register expressions for export in test mode
fillRow

Flex Box-based row/column layouts
exprToFunction

Convert an expression to a function
fileInput

File Upload Control
downloadHandler

File Downloads
fixedPage

Create a page with a fixed layout
fillPage

Create a page that fills the window
flowLayout

Flow layout
fluidPage

Create a page with fluid layout
inputPanel

Input panel
icon

Create an icon
headerPanel

Create a header panel
helpText

Create a help text element
getCurrentTheme

Obtain Shiny's Bootstrap Sass theme
getQueryString

Get the query string / hash component from the URL
htmlOutput

Create an HTML output element
httpResponse

Create an HTTP response object
getCurrentOutputInfo

Get output information
freezeReactiveVal

Freeze a reactive value
insertTab

Dynamically insert/remove a tabPanel
isolate

Create a non-reactive scope for an expression
invalidateLater

Scheduled Invalidation
knitr_methods

Knitr S3 methods
loadSupport

Load an app's supporting R files
makeReactiveBinding

Make a reactive variable
isRunning

Check whether a Shiny application is running
isTruthy

Truthy and falsy values
is.reactivevalues

Checks whether an object is a reactivevalues object
navlistPanel

Create a navigation list panel
markOutputAttrs

Mark a render function with attributes that will be used by the output
memoryCache

Create memory cache (deprecated)
markRenderFunction

Mark a function as a render function
insertUI

Insert and remove UI objects
modalDialog

Create a modal dialog UI
moduleServer

Shiny modules
navbarPage

Create a page with a top level navigation bar
maskReactiveContext

Evaluate an expression without a reactive context
markdown

Insert inline Markdown
numericInput

Create a numeric input control
outputOptions

Set options for an output object.
parseQueryString

Parse a GET query string from a URL
onStop

Run code after an application or session ends
onFlush

Add callbacks for Shiny session events
pageWithSidebar

Create a page with a sidebar
onBookmark

Add callbacks for Shiny session bookmarking events
plotOutput

Create an plot or image output element
observe

Create a reactive observer
observeEvent

Event handler
passwordInput

Create a password input control
reactive

Create a reactive expression
plotPNG

Capture a plot as a PNG file.
reactiveFileReader

Reactive file reader
reactivePoll

Reactive polling
radioButtons

Create radio buttons
reactiveVal

Create a (single) reactive value
reactiveTimer

Timer
reactiveValues

Create an object for storing reactive values
reactiveValuesToList

Convert a reactivevalues object to a list
reactiveConsole

Activate reactivity in the console
removeInputHandler

Deregister an Input Handler
reactlog

Reactive Log Visualizer
dataTableOutput

Table output with the JavaScript DataTables library
renderPrint

Text Output
registerInputHandler

Register an Input Handler
renderCachedPlot

Plot output with cached images
renderImage

Image file output
renderPlot

Plot Output
registerThemeDependency

Register a theme dependency
reexports

Objects exported from other packages
runGadget

Run a gadget
tableOutput

Table Output
addResourcePath

Resource Publishing
runApp

Run Shiny Application
req

Check for required values
repeatable

Make a random number generator repeatable
runExample

Run Shiny Example Applications
restoreInput

Restore an input value
renderUI

UI Output
runTests

Runs the tests associated with this Shiny app
shiny-package

Web Application Framework for R
setSerializer

Add a function for serializing an input before bookmarking application state
runUrl

Run a Shiny application from a URL
selectInput

Create a select list input control
shinyApp

Create a Shiny app object
session

Session object
shiny.appobj

Shiny App object
safeError

Declare an error safe for the user to see
serverInfo

Collect information about the Shiny Server environment
setBookmarkExclude

Exclude inputs from bookmarking
getShinyOption

Get or set Shiny options
showTab

Dynamically hide/show a tabPanel
showModal

Show or remove a modal dialog
showNotification

Show or remove a notification
showBookmarkUrlModal

Display a modal dialog for bookmarking
shinyDeprecated

Print message for deprecated functions in Shiny
shinyAppTemplate

Generate a Shiny application from a template
sidebarLayout

Layout a sidebar and main area
shinyUI

Create a Shiny UI handler
shinyServer

Define Server Functionality
sliderInput

Slider Input Widget
sizeGrowthRatio

Create a sizing function that grows at a given ratio
snapshotExclude

Mark an output to be excluded from test snapshots
snapshotPreprocessInput

Add a function for preprocessing an input before taking a test snapshot
submitButton

Create a submit button
tabPanel

Create a tab panel
snapshotPreprocessOutput

Add a function for preprocessing an output before taking a test snapshot
splitLayout

Split layout
stopApp

Stop the currently running Shiny app
updateCheckboxGroupInput

Change the value of a checkbox group input on the client
stacktrace

Stack trace manipulation functions
updateActionButton

Change the label or icon of an action button on the client
textOutput

Create a text output element
titlePanel

Create a panel containing an application title.
textAreaInput

Create a textarea input control
updateTextInput

Change the value of a text input on the client
textInput

Create a text input control
updateNumericInput

Change the value of a number input on the client
updateDateRangeInput

Change the start and end values of a date range input on the client
updateSliderInput

Update Slider Input Widget
updateSelectInput

Change the value of a select input on the client
updateDateInput

Change the value of a date input on the client
updateQueryString

Update URL in browser's location bar
updateRadioButtons

Change the value of a radio input on the client
updateCheckboxInput

Change the value of a checkbox input on the client
urlModal

Generate a modal dialog that displays a URL
tabsetPanel

Create a tabset panel
varSelectInput

Select variables from a data frame
verticalLayout

Lay out UI elements vertically
testServer

Reactive testing for Shiny server functions and modules
updateTextAreaInput

Change the value of a textarea input on the client
viewer

Viewer options
wellPanel

Create a well panel
updateTabsetPanel

Change the selected tab on the client
useBusyIndicators

Enable/disable busy indication
withProgress

Reporting progress (functional API)
withMathJax

Load the MathJax library and typeset math expressions
validate

Validate input values and other conditions
absolutePanel

Panel with absolute positioning
bindCache

Add caching with reactivity to an object
bindEvent

Make an object respond only to specified reactive events
NS

Namespaced IDs for inputs/outputs
Progress

Reporting progress (object-oriented API)