Spring - MVC Form Radio Button
Last Updated :
24 Feb, 2022
Here, we will learn about the Spring MVC radiobutton and radiobuttons tags. We will create a basic Spring MVC project in the Spring tool suite(STS) to create radiobuttons using form:radiobutton and form:radiobuttons tags.
'spring-form.tld' tag library
- In Spring Framework, we can use Java Server Pages (JSPs) as a view component. From version 2.0, Spring provides a comprehensive set of data binding-aware tags for handling form elements when using JSP and Spring Web MVC.
- Each tag in the spring tag library provides support for the set of attributes of its corresponding HTML tag counterpart, making the tags familiar and intuitive to use.
- Spring's form tag library namely 'spring-form.tld' is integrated with Spring Web MVC, giving the tag's access to the command object and reference data your controller deals with.
- The form tags make JSPs easier to develop, read and maintain.
- For example: to evaluate errors, setting themes, formatting the fields for inputting and outputting internationalized messages, etc.
- To use the tags from this library, we need to add the following directive at the top of the JSP page:
HTML
<%@ taglib prefix="form" uri="http://www.springframework.org/tags/form" %>
here the form is the tag name prefix that is used for the tags from this library.
'radiobutton' tag
The 'radiobutton' is one of the tag provided by the spring-form.tld library. It renders an HTML 'input' tag with type 'radio'.
HTML
<form:radiobutton path=" " value=" " label=" " />
'radiobuttons' tag
The 'radiobuttons' is one of the tag provided by the spring-form.tld library. It renders multiple HTML 'input' tags with type 'radio'.Â
- It will involve multiple tag instances bound to the same property but with different values by passing in the available options as a runtime variable.
- We can pass values as an Array, a List or a Map containing the available options in the  "items" property.
- If you are using a Map, the map entry key will be used as the value and the map entry's value will be used as the label to be displayed.
HTML
<form:radiobuttons path=" " items=" " />
Spring MVC Application
We will create the below Spring MVC application to learn how to use radiobutton tags.
Spring MVC - radiobutton exampleSteps to Create Application
- Create a Spring MVC project in Spring Tool Suite.
- In STS, while creating the project based on the developer selection, it will download all the required maven dependencies, *.jar, lib files and it will provide an embedded server.
- Below is the final project structure of the Spring MVC project after creating *.java and *.jsp files also.
Project Structure
Implementation: Files to be created are as follows:Â
- Choice.java - Bean class - To define the properties and getter/setter methods of the properties.
- ChoiceController.java - Controller class - To process the user request and generate the output.
- choice.jsp - Jsp file to interact with the user for the input.
- summary.jsp - Jsp file to display the output after processing to the user.
A. File: choice.jsp
HTML
<%@ page language="java" contentType="text/html; charset=ISO-8859-1"
pageEncoding="ISO-8859-1"%>
<%@taglib uri="http://www.springframework.org/tags/form" prefix="form"%>
<!DOCTYPE html>
<html>
<head>
<meta charset="ISO-8859-1">
<title>Welcome page</title>
</head>
<body>
<h1>Welcome to GeeksforGeeks!</h1>
<form:form action="submit" method="post" modelAttribute="choice">
<table>
<tr>
<td><form:label path="name">Enter your name: </form:label></td>
<td><form:input path="name" /></td>
</tr>
<tr>
<td><form:label path="job">Are you looking for a job now?: </form:label></td>
<td><form:radiobutton path="job" value="Yes" label="Yes" /> <form:radiobutton
path="job" value="No" label="No" /></td>
</tr>
<tr>
<td><form:label path="experience">Do you have work experience?: </form:label></td>
<td><form:radiobutton path="experience" value="Yes" label="Yes"
onclick="enable()" /> <form:radiobutton path="experience"
value="No" label="No" onclick="disable()" /></td>
</tr>
<tr>
<td><form:label path="years">How many years of experience you have?: </form:label></td>
<td><form:radiobuttons id="experienceYears" path="years"
items="${experienceYears}" delimiter="|" /></td>
</tr>
<tr>
<td><form:button>Submit</form:button></td>
</tr>
</table>
</form:form>
<script type="text/javascript">
function enable() {
document.getElementById("experienceYears1").disabled = false;
document.getElementById("experienceYears2").disabled = false;
document.getElementById("experienceYears3").disabled = false;
}
function disable() {
document.getElementById("experienceYears1").disabled = true;
document.getElementById("experienceYears2").disabled = true;
document.getElementById("experienceYears3").disabled = true;
}
</script>
</body>
</html>
This is the welcome page displayed to the user when the application starts. As we discussed above, we need to include the directive - "http://www.springframework.org/tags/form" in the JSP page to use Spring form tags. In the form tag-action, method attributes are used to map the controller method that has to be executed when JSP page submits. The radiobutton and radiobuttons tags have many attributes like id, path, cssStyle, dir, value, items, etc. We can include any number of attributes based on our project requirement.
In this example, we are using the below attributes as follows:Â
- path: To specify the path to the property that needs to be bind with the data. In this example, we have used path="experience" so that the both values - yes, no will bind to that path.
- id: Â To provide a unique id for the property. Here, we have given the value id="experienceYears", so that all the items that are displayed under the radiobuttons tag have this unique id. As there are 3 items in the list, the id will be provided as experienceYears1, experienceYears2, experienceYears3 for the respective item values at runtime.
- value: To specify the value to the particular radiobutton.
- label: To display the name of the value for the radiobutton.
- disabled: It is a boolean attribute to make the radiobutton disabled when the value is true. By default, the value will be false.
- items: To display the radiobutton names from the list.
- delimiter: To specify a delimiter to use between each 'input' tag with type 'radiobutton'. Here we are using '|' symbol as a delimiter.
- onclick: It is the event attribute, where the function specified will be executed when the user clicks on the radiobutton. Here, when the user clicks on Yes, enable() function will be executed and when the user clicks on the No, disable() function will be executed.
JavaScript FunctionsÂ
We are calling the javascript functions to enable/disable the radiobuttons.
- Finally, when the form is submitted, the container will check the method in the controller class having the URL - "/submit" with method - "post" and it will execute it to process the request.
B. File: Choice.java
Java
// Java Program to Illustrate Choice Class
package com.geek.app;
// Class
public class Choice {
// Class data members
private String name;
private String job;
private String experience;
private String years;
// Getter
public String getName() { return name; }
// Setter
public void setName(String name) { this.name = name; }
// Getter
public String getJob() { return job; }
// Setter
public void setJob(String job) { this.job = job; }
// Getter
public String getExperience() { return experience; }
// Setter
public void setExperience(String experience)
{
this.experience = experience;
}
// Getter
public String getYears() { return years; }
// Setter
public void setYears(String years)
{
this.years = years;
}
}
- This is the java bean class to define the required parameters.
- Here, we are defining name, job, experience, and years as parameters and their getter/setter methods to get and set the values to the respective properties.
C. File: ChoiceController.java
Java
// Java Program to illustrate ChoiceController Class
package com.geek.app;
// Importing required classes
import java.util.Arrays;
import java.util.List;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.ModelAttribute;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
// Annotation
@Controller
// Class
public class ChoiceController {
// Annotation
@RequestMapping(value = "/")
public String viewPage(Model model)
{
Choice choice = new Choice();
model.addAttribute("choice", choice);
return "choice";
}
// Annotation
@ModelAttribute("experienceYears")
public List<String> experienceYears()
{
List<String> years = Arrays.asList(
"1-3 Years", "3-5 years", "Above 5 Years");
return years;
}
// Annotation
@RequestMapping(value = "/submit",
method = RequestMethod.POST)
public String
submit(@ModelAttribute("choice") Choice choice)
{
return "summary";
}
}
- This is the controller class where it executes the methods based on the mapping of the request URLs.
- The annotation, @Controller, conveys to the container that this class is the spring controller class. To use this annotation we need to import org.springframework.stereotype.Controller package.
- The annotation, @RequestMapping, maps the request URL's to the specified method based on the value provided. To use this annotation, we need to import org.springframework.web.bind.annotation.RequestMapping package.
- So, when the URL request comes with the value="/submit", the container will execute the submit method of this class.
- The annotation @ModelAttribute, used to bind a method parameter or method return value to the named model attribute. We need to import org.springframework.web.bind.annotation.ModelAttribute package.
- The @ModelAttribute with the value "experienceYears", executes the method experienceYears to create list of items to be displayed in the radiobuttons tag.
- The RequestMethod specifies the type of the request from the user whether it is a get request or post request.
D. File: summary.jsp
HTML
<%@ page language="java" contentType="text/html; charset=ISO-8859-1"
pageEncoding="ISO-8859-1"%>
<!DOCTYPE html>
<html>
<head>
<meta charset="ISO-8859-1">
<title>Summary page</title>
</head>
<body>
<h3>Hello ${choice.name}!!</h3>
<span>Looking for a job: </span>
<span>${choice.job}</span>
<br>
<span>Work experience: </span>
<span>${choice.experience}</span>
<br>
<span>Years of experience: </span>
<span>${choice.years}</span>
</body>
</html>
This is the output Jsp page to display the user-selected values in the browser after the processing of the request.
Execution/Output:
- After creating all the required .java and .jsp files, run the project on the embedded server.
- Right on the Project, Run as -> Run on Server.
- Select the server in the localhost to run the application.
- Open the URL: http://localhost:8080/app/ in the browser to get the below screen.
Welcome page - choice.jsp
Scenario 1: Enter the name, select the option No for Do you have work experience? field as below,
Scenario 1: Input- As we selected option No for Do you have work experience? field, all the radiobuttons of How many years of experience you have? the field is disabled.
- Now, click on submit button to get the output.
Scenario 1: Output
Scenario 2: Now, select option yes for Do you have work experience? field.
Scenario 2: Input- As we selected option Yes for Do you have work experience? field, all the radiobuttons of How many years of experience you have? field is enabled. Select the desired option.
- Click on submit button to get the output.
Scenario 2: Output
This way we can use the tags radiobutton and radiobuttons in the application where the user needs to choose an option and we can include different attributes based on the project requirement.
Similar Reads
OpenSource REST API URL and Retrieving Data From it By Using Spring MVC
In this internet era, a lot of helper services are available in the form of REST API and mostly REST API provides us the details in the form of JSON/XML. We can use them in our applications and render the data as we like. Here is the list of a few opensource REST API URLs: API NameDescriptionURLCoin
6 min read
How to Resolve WEB xml is missing and failOnMissingWebXml is set to true in Eclipse/STS?
Eclipse/STS IDE is generally used to develop Spring applications and what happens is whenever we are creating a simple Maven project and if the web.xml is missing or you have deleted that file then you may encounter this problem inside the pom.xml file corresponding to which do refer to the below im
2 min read
Spring MVC Application Without web.xml File
Spring MVC framework enables separation of modules namely Model, View, and Controller, and seamlessly handles the application integration. This enables the developer to create complex applications also using plain java classes. Here we will be creating and running Your First Spring MVC Application,
4 min read
Spring - MVC Listbox
Spring Web MVC framework to demonstrate how to utilize Listbox in forms. Let's start by setting up an Eclipse IDE and then following the steps to create a Dynamic Form-based Web Application utilizing the Spring Web Framework. The items are listed in the Spring MVC form Listbox. This tag creates a se
4 min read
Spring MVC - Multiple Resolver Mapping
Spring MVC Framework provides the feature of View Resolver through which you can map a view to its respective view and render the model in your browser. The View Resolver eliminates the use of view technologies like Velocity and JSP. There are many view resolvers available in spring-like InternalRes
4 min read
How to Extract TV Show Details via REST API and Spring MVC?
REpresentational State Transfer (REST) is an architectural style that defines a set of constraints to be used for creating web services. REST API is a way of accessing web services in a simple and flexible way without having any processing. Spring MVC is a Web MVC Framework for building web applicat
9 min read
Spring MVC File Upload
Spring MVC provides a robust mechanism for handling file uploads in web applications. Using Spring MVC file upload, developers can easily integrate multipart file handling with the CommonsMultipartResolver. This article covers how to upload files in Spring MVC, configure MultipartResolver, and manag
6 min read
Spring MVC - Tiles
Spring provides functionality for integrating with the Apache Tiles framework. With the help of spring tiles support, we can easily manage the layout of the Spring MVC application. Benefits of Spring MVC's Tiles support: The following are some of the primary benefits of Spring MVC Tiles 3 Integratio
4 min read
Spring MVC - Text Box
To begin, make sure you have a working Eclipse IDE installed and follow the steps below to create a Spring Web Framework-based Dynamic Form-based Web Application. Steps to create TextBox in Spring MVC: Create a SpringMVCTextField project in the com.geeksforgeeks package.Under the com.geeksforgeeks p
3 min read
Spring MVC - Multiple Controller
We may construct numerous controllers at once in Spring MVC. Each controller class must be annotated with the @Controller annotation. A Spring MVC example with numerous controllers can be found here. The procedure is as follows: In the case of Maven, load the spring jar files or add dependencies.Mak
2 min read