Shiny Application Layouts Exercises (Part-4)

[This article was first published on R-exercises, and kindly contributed to R-bloggers]. (You can report issue about the content on this page here)
Want to share your content on R-bloggers? click here if you have a blog, or here if you don't.

Shiny Application Layouts – Navbar Page Features

In the fourth part of our series we will see some of the most important features that a Navbar page provides in order to enhance the appearance of our shiny application.

We will use the “Cars” app which we built in Shiny Application Layouts-Navbar Page.

This part can be useful for you in two ways.

First of all, you can see different ways to enhance the appearance and the utility of your shiny app.

Secondly you can make a revision on what you learnt in “Building Shiny App” series as we will build basic shiny staff in order to present it in the proper way.

Read the examples below to understand the logic of what we are going to do and then test yous skills with the exercise set we prepared for you. Lets begin!

Answers to the exercises are available here.

Navbar Arguments

This is a basic navbarPage() function with a title:

You can use selected to select the value of the tab that should be selected by default. If NULL, the first tab will be selected.

Exercise 1

Change the title to your navigation bar to “Cars App”. Then name it “Cars” again.

Exercise 2

Add value to all of your tabPanel.

Learn more about Shiny in the online course R Shiny Interactive Web Apps – Next Level Data Visualization. In this course you will learn how to create advanced Shiny web apps; embed video, pdfs and images; add focus and zooming tools; and many other functionalities (30 lectures, 3hrs.).

Exercise 3

Select the tabPanel of the “Data Table” as default. Then deactivate it.

With position you can choose whether the navbar should be displayed at the top of the page with normal scrolling behavior (“static-top”), pinned at the top (“fixed-top”), or pinned at the bottom (“fixed-bottom”).

Exercise 4

Set the navbar position to “fixed-bottom”. Then deactivate it.

With inverse set to TRUE you will take a black background and light text for the navigation bar.
navbarPage("Cars",selected="tab",position="fixed-bottom",inverse= T)

Exercise 5

Change the color of the navigation bar to black.

If you set collapsible to TRUE the navigation elements are collapsed into a menu when the width of the browser is less than 940 pixels.
navbarPage("Cars",selected="tab",position="fixed-bottom",inverse= T,collapsible =T)

Exercise 6

Collapse your navigation elements.

You can set fluid to TRUE to use a fluid layout.
navbarPage("Cars",selected="tab",position="fixed-bottom",inverse= T,collapsible =T,fluid =T)

Exercise 7

Set fluid to FALSE.

You can also use headerPanel() to create an application title.Look at the example:
tabPanel("Plot", value = "pl",headerPanel("PLOT"), sidebarLayout( sidebarPanel( radioButtons("plote", "Plot", c("Scatter"="p", "Line"="l") ) ), mainPanel( plotOutput("plot") ) ))

Exercise 8

Create four headerPanel(). One for every tabPanel and name them as the respective tabPanel.

You can use position in your sidebarLayout to place the sidebar from left to right. Look at the example:
sidebarLayout(position="right", sidebarPanel( radioButtons("plote", "Plot", c("Scatter"="p", "Line"="l") ) ), mainPanel( plotOutput("plot") ) )

Exercise 9

Move your sidebar to the right.

You can also name your navbarMenu like this:

Exercise 10

Giva a title to your navbarMenu.

To leave a comment for the author, please follow the link and comment on their blog: R-exercises. offers daily e-mail updates about R news and tutorials about learning R and many other topics. Click here if you're looking to post or find an R/data-science job.
Want to share your content on R-bloggers? click here if you have a blog, or here if you don't.

Never miss an update!
Subscribe to R-bloggers to receive
e-mails with the latest R posts.
(You will not see this message again.)

Click here to close (This popup will not appear again)