Open In App

Spring – MVC Form Radio Button

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




<%@ 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’.






<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’. 




<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 example

Steps to Create Application

  1. Create a Spring MVC project in Spring Tool Suite.
  2. 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.
  3. 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: 

  1. Choice.java – Bean class – To define the properties and getter/setter methods of the properties.
  2. ChoiceController.java – Controller class – To process the user request and generate the output.
  3. choice.jsp – Jsp file to interact with the user for the input.
  4. summary.jsp – Jsp file to display the output after processing to the user.

A. File: choice.jsp




<%@ 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: 

  1. 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.
  2. 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.
  3. value: To specify the value to the particular radiobutton.
  4. label: To display the name of the value for the radiobutton.
  5. disabled: It is a boolean attribute to make the radiobutton disabled when the value is true. By default, the value will be false.
  6. items: To display the radiobutton names from the list.
  7. delimiter: To specify a delimiter to use between each ‘input’ tag with type ‘radiobutton’. Here we are using ‘|’ symbol as a delimiter.
  8. 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.

B. File: Choice.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;
    }
}

C. File: ChoiceController.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";
    }
}

D. File: summary.jsp




<%@ 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:

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

Scenario 1: Output

Scenario 2: Now, select option yes for Do you have work experience? field.

Scenario 2: Input

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.


Article Tags :