struts ajax多级下拉菜单
先看项目截图:
看看要加入的jar包
除了struts核心的那个几个之外,我们还需要这两个
OK先看struts.xml
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE struts PUBLIC
"-//Apache Software Foundation//DTD Struts Configuration 2.1//EN"
"http://struts.apache.org/dtds/struts-2.1.dtd">
<struts>
<constant name="struts.devMode" value="true"></constant>
<package name="test" namespace="/" extends="struts-default">
<action name="getProvince" class="cdm.module.file.action.SearchFileAction" method="getProvince">
<result>/testSelect.jsp</result>
</action>
</package>
<package name="searchFileJSON" namespace="/" extends="json-default">
<action name="getMunicipality" class="cdm.module.file.action.SearchFileAction" method="getMunicipality">
<result type="json">
<param name="root">municipalities</param>
</result>
</action>
</package>
</struts>
我们看看用于处理请求的类。
package cdm.module.file.action;
import java.util.ArrayList;
import java.util.List;
import com.opensymphony.xwork2.ActionSupport;
public class SearchFileAction extends ActionSupport {
/**
*
*/
private static final long serialVersionUID = -6756954284459457436L;
public int provinceId;
public List<Municipality> municipalities;
public List<Province> provinces=new ArrayList<Province>();
public String getProvince(){
//下面的为模拟数据库操作
Province p1=new Province();
p1.setId(1);
p1.setName("陕西省");
Province p2=new Province();
p2.setId(2);
p2.setName("山西省");
provinces.add(p1);
provinces.add(p2);
return SUCCESS;
}
public String getMunicipality(){
municipalities=new ArrayList<Municipality>();
//下面的为模拟数据库操作
if (provinceId==1) {
Municipality municipality=new Municipality();
municipality.setId(1);
municipality.setName("咸阳市");
municipality.setProvinceId(1);
municipalities.add(municipality);
municipality=new Municipality();
municipality.setId(2);
municipality.setName("西安市");
municipality.setProvinceId(1);
municipalities.add(municipality);
}
if (provinceId==2) {
Municipality municipality=new Municipality();
municipality.setId(1);
municipality.setName("运城市");
municipality.setProvinceId(2);
municipalities.add(municipality);
municipality=new Municipality();
municipality.setId(2);
municipality.setName("太原市");
municipality.setProvinceId(2);
municipalities.add(municipality);
}
System.out.println(municipalities.get(0).getName()+"sdfs");
return SUCCESS;
}
//省略三个实例变量的getset方法
}
至于Municipality,与Province,省里面有个一id和name,市除了id和name外还有一个provinceId,来指示它位于哪个省。
testSelect.jsp也很简单就是下面代码示例。
<%@ page contentType="text/html; charset=GB2312"%>
<%@taglib prefix="s" uri="/struts-tags"%>
<html>
<head>
<title></title>
<script type="text/javascript" src="js/json2.js"></script>
<script type="text/javascript" src="js/prototype.js"></script>
<script type="text/javascript" src="js/findInf.js"></script>
</head>
<body>
<br>
<table class="tab_frm" >
<tr>
<td class="left" width="5%">
省级别
</td>
<td class="left" width="18%">
市级别
</td>
</tr>
<tr>
<td class="center" width="5%">
<s:select id="categoryId0" list="provinces"
listKey="id" listValue="name" headerKey="-1"
headerValue="-请选择省-" theme="simple"
onchange="getProvince(this)" />
</td>
<td class="center" width="18%">
<s:select id="conditionId0" list="#{'-1':'-请先选择省-'}"
theme="simple" disabled="true" />
</td>
</tr>
</table>
</body>
</html>
核心在引入的findInf.js,代码如下:
function getProvince(obj) {
var provinceId = obj.options[obj.selectedIndex].value;
var select = document.getElementById("conditionId0");
if (provinceId < 0) {
select.innerHTML = "";
select1.innerHTML = "";
var con = new Option();
con.text = "-请先选择省-";
con.value = "-1";
var mat = new Option();
mat.text = "-请先选择省-";
mat.value = "-1";
select.options.add(con);
select.disabled=true;
return;
}
var url = "getMunicipality.action?provinceId=" + provinceId;
new Ajax.Request(url, {method:"post", onComplete:function (request) {
select.innerHTML = "";
var o = new Option();
o.text = "-请选择市-";
o.value = "-1";
select.options.add(o);
var tableList = JSON.parse(request.responseText);
for (var i = 0; i < tableList.length; i++) {
var _o = new Option();
_o.text = tableList[i].name;
_o.value = tableList[i].id;
select.options.add(_o);
}
select.disabled=false;
}, asynchronous:true});
}
完工!
遇到的几个问题
<script type="text/javascript" src="js/json2.js"></script>
<script type="text/javascript" src="js/prototype.js"></script>
<script type="text/javascript" src="js/findInf.js"></script>
findInf要等上面两个引入后才能引用。
当时复制的时候没有注意这一点。
启用firefox的调试功能,看到Ajax is not define 才想到这个问题。
其他资料:
http://www.jb51.net/article/37316.htm
http://www.wzsky.net/html/Website/Javascript/126012.html
http://www.w3school.com.cn/jquery/ajax_ajax.asp
struts ajax多级下拉菜单的更多相关文章
- jquery实现多级下拉菜单
支持多种浏览器,体验效果:http://keleyi.com/keleyi/phtml/jqmenu/4.htm 多级菜单,理论上支持无限多的层级,文件结构非常简单的,以下是完整代码: <!DO ...
- 基于jQuery带图标的多级下拉菜单
之前为大家分享了很多导航菜单.今天我们要来分享一款很不错的jQuery左侧带小图标的多级下拉菜单,菜单是垂直的,每一个菜单项带有一个小图标,看起来非常专业.并且菜单支持无限极下拉,所以对各位Web开发 ...
- 一款多浏览器兼容的javascript多级下拉菜单
这个多级下拉菜单的脚本大小不到2K,带有动画效果,可以方便地支持多个实例,并且能良好兼容WordPress系统wp_list_cats和wp_list_pages生成的多级列表.要初始化一个菜单,只需 ...
- 小程序多级下拉菜单demo
小程序多级下拉菜单demo - CSDN博客 https://blog.csdn.net/github_39371177/article/details/80251211
- bootstrap多级下拉菜单
只需为下拉菜单的任意 <li> 元素添加 .dropdown-submenu 的类,并在该 <li> 元素下添加 .dropdown-menu 类的列表,就可以为该菜单项添加一 ...
- jQuery制作水平多级下拉菜单
本篇体验使用jQuery制作水平的.多级的.下拉菜单. 下拉菜单的html部分如下. <body> <nav class="main-nav"> <u ...
- AJAX多级下拉联动【JSON】
前言 前面我们已经使用过了XML作为数据载体在AJAX中与服务器进行交互.当时候我们的案例是二级联动,使用Servlet进行控制 这次我们使用JSON作为数据载体在AJAX与服务器交互,使用三级联动, ...
- ajax实现下拉菜单无刷新加载更多
$(function() { var page = 1; var discount = $('#discount'); var innerHeight = window.innerHeight; va ...
- android 多级下拉菜单实现教程
原创,如转载请标明链接:http://blog.csdn.net/q610098308/article/details/50333387 很多App,都有二级菜单出现,但android 本身实现的菜单 ...
随机推荐
- self关键字
self关键字 self:当前类/对象的指针(指向当前对象/方法调用者) 作用1 当类里有变量名和成员变量名一样的时候,可以使用self区分 例: 我们写一个人的类,有一个年龄属性,在get方法里,我 ...
- cassandra 3.x官方文档(2)---架构解析
写在前面 cassandra3.x官方文档的非官方翻译.翻译内容水平全依赖本人英文水平和对cassandra的理解.所以强烈建议阅读英文版cassandra 3.x 官方文档.此文档一半是翻译,一半是 ...
- java 随机数高效生成
分享牛,分享牛原创.近期去面试经常被问到java如何生产随机数,以及生成很大的字符串保证不能重复,还要考虑性能,之前本人面试别人的时候,可能不会问这个问题.既然这个java随机数问题经常被问到,那咱们 ...
- android 集成微博常见问题
我们在做微博集成登录.分享.聊天的时候,肯定会遇到很多的坑,这里总结下常见的问题. 文件不存在 C8998 的解决方法 如图我们走微博授权登录的时候如果OAuth2.0 授权设置回调页面设置和本地的不 ...
- POI操作excel中的日期格式处理
转载:http://blog.csdn.net/fuxiaohui/article/details/6239925 7.3.3 POI中Excel文件Cell的类型 在读取每一个Cell的值的时候,通 ...
- Tomcat内核之类加载器工厂
Java虚拟机利用类加载器将类载入内存,以供使用.在此过程中类加载器要做很多的事情,例如读取字节数组.验证.解析.初始化等.而Java提供的URLClassLoader类能方便地将jar.class或 ...
- Hibernate初体验及简单错误排除
Hibernate是什么,有多少好处,想必查找这类博文的都知道,所以就不多说了.下面是我对Hibernate简单使用的一个小小的总结.与君(主要是刚入门的)共勉吧! 创建的顺序 创建Hibernate ...
- MySQL聚簇索引的使用介绍
MySQL聚簇索引保证关键字的值相近的元组存储的物理位置也相同(所以字符串类型不宜建立聚簇索引,特别是随机字符串,会使得系统进行大量的移动操作),且一个表只能有一个聚簇索引.因为由存储引擎实现索引,所 ...
- 新手学python(2):C语言调用完成数据库操作
继续介绍本人的python学习过程.本节介绍如何利用python调用c代码.内容还是基于音乐信息提取的过程,架构如图一.Python调用c实现的功能是利用python访问c语言完成mysql数据库操作 ...
- Android Studio(AS)-->导入项目
1:首先,你必须要有一个工程(Project), 才可以打开项目(Module); (注意:Eclipse中的Workspace对应Android Studio 中的Project, Eclipse中 ...