Struts 2 sx:autocompleter UI tag

<sx:autocompleter>:

The <sx:autocompleter> tag is used to create auto completer i.e. it creates a input box when user write something it automatically generates a drop down suggestion list. It is dojo ajax tag.

Syntax:

<sx:autocompleter label="fieldLabel" list="valueList" name="fieldName" />

Note: Add <sx:head /> in the head element of your jsp.

Example:

index.jsp

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
  <head>
  	<title>Struts 2 s:autocompleter UI tags example</title>
	<META HTTP-EQUIV="Refresh" CONTENT="0;URL=initializeList.action">
  </head>  
  <body>
  </body>
</html>

test.jsp

<%@ taglib uri="/struts-tags" prefix="s"%>
<%@ taglib uri="/struts-dojo-tags" prefix="sx"%>
<html>
	<head>
		<title>Struts 2 s:autocompleter UI tags example</title>
		<sx:head />
	</head>
	<body>
		<h3>This is a s:autocompleter UI tags example.</h3>
 
		<s:form action="Test">
			<sx:autocompleter label="Enter subject" 
			list="subjectList" name="selectedSubject" />
			<s:submit value="Submit"/>
		</s:form>
 
	</body>
</html>

web.xml

<?xml version="1.0" encoding="UTF-8"?>
<web-app version="2.5" 
	xmlns="http://java.sun.com/xml/ns/javaee" 
	xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
	xsi:schemaLocation="http://java.sun.com/xml/ns/javaee 
	http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd">
 
 
 	<filter>
	  <filter-name>struts2</filter-name>
	  <filter-class>
        	org.apache.struts2.dispatcher.ng.
        	filter.StrutsPrepareAndExecuteFilter
          </filter-class>
	</filter>
 
	<filter-mapping>
		<filter-name>struts2</filter-name>
		<url-pattern>/*</url-pattern>
	</filter-mapping>
 
	<welcome-file-list>
	  <welcome-file>index.jsp</welcome-file>
	</welcome-file-list>
 
</web-app>

struts.xml

<!DOCTYPE struts PUBLIC
"-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"
"http://struts.apache.org/dtds/struts-2.0.dtd">
 
<struts>
 
	<package name="default" extends="struts-default">
	 <action name="initializeList" 
	   class="com.w3schools.action.Test" method="initializeList">
		<result name="none">/test.jsp</result>
	 </action>
 
	 <action name="Test" class="com.w3schools.action.Test">
		<result name="success">/welcome.jsp</result>
	 </action>
	</package>
 
</struts>

Test.java

import java.util.ArrayList;
import java.util.List;
import com.opensymphony.xwork2.ActionSupport;
 
/**
 * This class is used as an action class.
 * @author w3schools
 */
public class Test extends ActionSupport{
	//data members
	private List<String> subjectList;
	private String selectedSubject;
 
	//business logic
	public String execute(){
		return SUCCESS;	
	}
 
	//getter setters
	public List<String> getSubjectList() {
		return subjectList;
	}
 
	public void setSubjectList(List<String> subjectList) {
		this.subjectList = subjectList;
	}
 
	public String getSelectedSubject() {
		return selectedSubject;
	}
 
	public void setSelectedSubject(String selectedSubject) {
		this.selectedSubject = selectedSubject;
	}	
 
	public String initializeList(){
		subjectList = new ArrayList<String>();
		subjectList.add("Java");
		subjectList.add("C");
		subjectList.add("C++");
		subjectList.add("Compiler");
		subjectList.add("DBMS");
		subjectList.add("Data Structure");
 
		return NONE;
	}	
 
}

welcome.jsp

<%@ taglib uri="/struts-tags" prefix="s"%>
<html>
	<head>
		<title>Struts 2 s:autocompleter UI tags example</title>
	</head>
	<body>
		<h3>This is a s:autocompleter UI tags example.</h3>
 
		Subject: <s:property value="selectedSubject" />
 
	</body>
</html>

Output:

struts 40 first
 
Enter subject.
struts 40 second
 
Click on Submit button.
struts 40 final
 
Download this example.
 
Next Topic: Struts 2 control tags with example.
Previous Topic: Struts 2 s:datetimepicker UI tag with example.