`
锅巴49
  • 浏览: 163973 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

用dwr做级联下拉表单

阅读更多

级联下拉表单的做法有很多种,如jquery ajax,dwr等。

现在我介绍下用dwr的做法。

 

实现目标:

 

两级地域下拉表单

 A      B

 

A中有三个选项:全部,北京,上海

当A选全部时,B中出现全部

当A选北京时,B中出现全部,朝阳区,海淀区

当A选上海时,B中出现全部,浦东区,普坨区

 

1、下载dwr-2.0.rc1.jar,放入WEB-INIF/lib,附件中有。

2、在web.xml中加入

<servlet>
		<servlet-name>dwr-invoker</servlet-name>
		<servlet-class>org.directwebremoting.servlet.DwrServlet</servlet-class>
		<init-param>
			<param-name>debug</param-name>
			<param-value>true</param-value>
		</init-param>
		<init-param>
			<param-name>crossDomainSessionSecurity</param-name>
			<param-value>false</param-value>
		</init-param>
	</servlet>
	<servlet-mapping>
		<servlet-name>dwr-invoker</servlet-name>
		<url-pattern>/dwr/*</url-pattern>
	</servlet-mapping>

 

我加在struts的filter之后

 

3、新建Area类,地域对象

package com.my.dwr;

/**
 * 
 * @author 锅巴
 * @date 2011-3-6
 * @description
 */
public class Area {

	private String name;
	
	private int code;

	public String getName() {
		return name;
	}

	public void setName(String name) {
		this.name = name;
	}

	public int getCode() {
		return code;
	}

	public void setCode(int code) {
		this.code = code;
	}
	
	
}

 

 

4、新建AreaService对象,业务对象

package com.my.dwr;

import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

/**
 * 
 * @author 锅巴
 * @date 2011-3-6
 * @description
 */
public class AreaService {

	private Map<Integer,List<Area>> areaMap = null;
	

	
	private List<Area> parentAreas = null;
	
	public AreaService(){
		
		areaMap = new HashMap<Integer, List<Area>>();
		parentAreas = new ArrayList<Area>();
		
		Area area = new Area();
		area.setCode(-1);
		area.setName("全部");
		
		Area area0 = new Area();
		area0.setCode(1);
		area0.setName("北京");
		
		Area area1 = new Area();
		area1.setCode(2);
		area1.setName("上海");
		
		Area area0_0 = new Area();
		area0_0.setCode(-1);
		area0_0.setName("全部");
		
		Area area0_1 = new Area();
		area0_1.setCode(3);
		area0_1.setName("朝阳区");
		
		Area area0_2 = new Area();
		area0_2.setCode(4);
		area0_2.setName("海淀区");
		
		Area area1_0 = new Area();
		area1_0.setCode(-1);
		area1_0.setName("全部");
		
		Area area1_1 = new Area();
		area1_1.setCode(5);
		area1_1.setName("浦东区");
		
		Area area1_2 = new Area();
		area1_2.setCode(6);
		area1_2.setName("普坨区");
		
		parentAreas.add(area);
		parentAreas.add(area0);
		parentAreas.add(area1);
		
		
		List<Area> areas = new ArrayList<Area>();
		areas.add(area);
		
		areaMap.put(-1, areas);
		
		
		List<Area> area0s = new ArrayList<Area>();
		area0s.add(area0_0);
		area0s.add(area0_1);
		area0s.add(area0_2);
		areaMap.put(1, area0s);
		
		List<Area> area1s = new ArrayList<Area>();
		area1s.add(area1_0);
		area1s.add(area1_1);
		area1s.add(area1_2);
		areaMap.put(2, area1s);
		
		
	}
	
	

	
	public List<Area> getAreasByParentId(int areaId){
		return areaMap.get(areaId);
	}
	
	public List<Area> getParentAreas(){
		return parentAreas;
	}
	
}

 

5、在WEB-INF/中新建dwr.xml文件

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE dwr PUBLIC "-//GetAhead Limited//DTD Direct Web Remoting 2.0//EN"  "http://www.getahead.ltd.uk/dwr/dwr20.dtd"> 
<dwr>
	<allow>
		<!-- 从spring ioc 中获取 -->
		<create creator="spring" javascript="JAreaSelect">
			
			<param name="beanName" value="areaService" />

			 <!-- 可以指定暴露的方法
			 <include method="Register" />
			  -->
			 
		</create>
		
		<!--  直接生成一个实例
		<create creator="new" javascript="JAreaSelect">
			<param name="class" value="com.my.dwr.AreaService" />
		</create>
		-->
		
		<!-- 将area转成json -->
		<convert converter="bean" match="com.my.dwr.Area">
			<!-- 
			可以指定要输出的属性
			<param name="include" value="storeId,fullName,city,address,phoneURL,photoURL,DetailURL,posx,posy,discount,discountnotes"/>
			 -->
		</convert>
	</allow>
</dwr>

 

 

6、新建dwr.jsp页面,

<%@ page language="java" contentType="text/html; charset=UTF-8"
	pageEncoding="UTF-8" isErrorPage="true"%>
<%@taglib prefix="s" uri="/struts-tags"%>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
</head>
<body>
<select id="parentArea" onchange="changeParentArea();return false;">
	<s:iterator value="parentAreas">
		<option value="<s:property value='code'/>"><s:property
			value="name" /></option>
	</s:iterator>
</select>
&nbsp;&nbsp;&nbsp;&nbsp;
<select id="childArea">
	<option value="-1">全部</option>
</select>
<script language=javascript>
	function changeParentArea() {
		var the_index = $("parentArea").selectedIndex;
		var the_selected = $("parentArea").options[the_index];
		JAreaSelect.getAreasByParentId(the_selected.value,
				changeParentAreaCallback);
	}

	function changeParentAreaCallback(childs) {
		var selectName = document.getElementById("childArea");
		selectName.options.length = 0;

		for ( var j = 0; j < childs.length; j++) {
			area = childs[j];
			selectName.options[j] = new Option(area.name, area.code);
		}
	}
</script>
<!-- dwr 引入的 文件 -->
<script type='text/javascript' src='/dwr/interface/JAreaSelect.js'></script>
<script type='text/javascript' src='/dwr/engine.js'></script>
<script type="text/javascript" src="/dwr/util.js">
	
</script>
</body>
</html>

 

 

7、建一个action导向该jsp,url为:/common/dwr.html

package com.my.action;

import java.util.List;

import com.my.dwr.Area;
import com.my.dwr.AreaService;
import com.opensymphony.xwork2.ActionSupport;

/**
 * 
 * @author 锅巴
 * @date 2011-3-6
 * @description
 */
public class Dwr extends ActionSupport{
	
	/**
	 * 
	 */
	private static final long serialVersionUID = 1L;

	private AreaService areaService;

	private List<Area> parentAreas;
	
	@Override
	public String execute() throws Exception {
		// TODO Auto-generated method stub
		
		parentAreas = areaService.getParentAreas();
		
		return SUCCESS;
	}

	
	
	
	public List<Area> getParentAreas() {
		return parentAreas;
	}





	public void setAreaService(AreaService areaService) {
		this.areaService = areaService;
	}
	
	
	

}

 

 

可以访问/common/dwr.html了,试试下拉的效果

0
2
分享到:
评论

相关推荐

    ssh+dwr 3级联

    在"ssh+dwr 3级联"的场景中,可能是指在一个项目中,使用SSH作为后端服务的安全访问层,DWR作为前后端交互的技术,而“3级联”可能指的是三层架构,即表示层(Presentation Layer)、业务逻辑层(Business Logic ...

    AJAX-DWR下拉框级联

    AJAX-DWR下拉框级联是Web开发中一种常见的交互设计,主要用于提高用户体验,使得用户在选择某个选项时,相关联的下拉框能够自动更新其内容,以适应不同的场景需求。在这个实验中,我们将重点探讨如何使用AJAX和DWR...

    DWR+hibernate+spring级联下拉列表框

    总结,DWR、Hibernate 和 Spring 结合使用可以方便地实现级联下拉列表框,提供流畅的用户体验。通过 DWR 实现前后端的实时通信,利用 Hibernate 进行数据操作,借助 Spring 管理业务逻辑和数据访问,从而构建出高效...

    dwr 实现 级联菜单 外加一本pdf的参考书

    结合上述描述,我们可以看出提供的PDF参考书可能详细介绍了如何使用DWR来实现级联菜单的步骤,包括但不限于以下内容: 1. **环境搭建**:介绍如何配置DWR框架,包括添加依赖、配置DWR的Context.xml和web.xml文件,...

    DWR级联菜单下拉框

    在这个项目中,我们关注的是如何利用DWR实现一个三级联动的下拉菜单。这种交互式菜单在用户界面设计中常见,用于在多个选项之间建立关联,如省份-城市-区县的选择,以提供更加精细化的筛选。 首先,我们需要理解DWR...

    使用DWR框架处理下拉列表的级联

    这个demo演示了使用DWR框架配合数据库来做的下拉列表级联。dao层采用了jsp中经典的JDBC封装、单例、属性文件等技术。数据文件可以按照我的entity层里面写的代码创建就可以了。这个文件直接导入你的工程在属性文件中...

    dwr的小小运用实现下拉列表

    在"**dwr的小小运用实现下拉列表**"这个主题中,我们关注的是如何利用DWR来创建和更新页面上的级联下拉列表。级联下拉通常用于需要关联数据的情况,例如国家/地区和城市的选择,其中选择一个国家后,下拉列表会自动...

    dwr例子演示级联菜单

    这个例子“dwr例子演示级联菜单”旨在帮助我们理解如何使用DWR来创建动态的、交互式的级联下拉菜单。级联菜单常用于Web应用程序中,例如在选择国家时自动更新相应的省份列表。 首先,让我们了解一下DWR的基本工作...

    Ajax的dwr框架实现级联

    级联通常用于数据表单中,如地区选择,省份改变时城市会随之更新,城市改变时区县也会相应变化。这种功能在很多实际应用场景中都非常常见,如地址管理、部门组织结构等。 首先,我们需要了解DWR的基本概念。DWR允许...

    dwr-下拉菜单实现

    #### 如何使用DWR实现下拉菜单 1. **配置DWR环境** - 首先确保项目中已经正确配置了DWR环境,包括导入DWR相关的jar包、配置web.xml和dwr.xml等。 - 在前端页面中引入DWR的JavaScript库。 2. **编写服务器端逻辑*...

    简单DWR动态下拉菜单

    5. **更新下拉菜单**:当服务器返回新数据后,使用DWR的`DWRUtil.removeAllOptions`清除现有选项,再用`DWRUtil.addOptions`添加新数据到下拉菜单。这样,菜单就能实时更新了。 6. **错误处理**:别忘了处理可能...

    Ajax级联菜单,通过dwr框架实现省份城市级联效果

    在这个特定的场景中,我们利用Ajax技术和Direct Web Remoting(DWR)框架来创建一个动态的省份城市级联菜单。这个功能能够提升用户体验,因为它减少了用户手动刷新页面的需求,提供了流畅的交互。 首先,我们需要...

    dwr实现2级级联菜单(sql2000 数据库)

    本篇文章将深入探讨如何利用DWR来实现一个两级级联菜单,并以SQL Server 2000数据库作为数据源。 首先,我们需要理解DWR的基本工作原理。DWR允许在后台执行Java方法并返回结果到前端,无需刷新整个页面。这种技术...

    SSH+dwr实现三级级联

    在这个场景中,“SSH + dwr 实现三级级联”指的是使用SSH框架与DWR技术结合,来实现前端页面中的多级联动下拉框功能。 首先,让我们详细了解一下SSH框架: 1. **Struts**:这是一个基于MVC(Model-View-Controller...

    级联菜单 java+dwr

    要使用DWR,你需要在项目中配置DWR的Servlet,并在Java类中添加可被远程调用的方法。 对于数据库部分,这里选择了SQL Server 2000。在实现级联菜单时,通常需要三个表:一个存储顶级分类,另一个存储子分类,第三个...

    DWR 联动下拉菜单基本应用

    在本例中,我们将讨论如何利用DWR2版本创建一个联动下拉菜单,这是一种常见的级联选择功能,常见于数据输入表单中,如地址选择,省-市-区的逐级筛选。 首先,我们需要在服务器端设置DWR引擎。这包括创建一个`dwr....

    dwr实现select列表的动态级联

    在“dwr实现select列表的动态级联”这个场景中,DWR将被用来实现在前端JavaScript和后端Java之间的数据同步,以便在用户选择上级选项时动态更新下级选项列表。以下是实现这个功能的关键步骤: 1. **设置DWR配置**:...

    dwr省市区三级级联

    标题 "dwr省市区三级级联" 涉及到的是一个前端开发中的常见问题,即如何实现省市区的三级联动效果。这个标题暗示我们这是一个使用Direct Web Remoting (DWR) 技术来实现的功能,它允许JavaScript与服务器端Java代码...

    ssh+dwr(实现3级联)

    SSH (Struts2 + Spring + Hibernate) 和 DWR (Direct Web Remoting) 是两种常见的Java Web开发技术。在本文中,我们将深入探讨如何将这两种技术结合,实现一个三级联动的效果。 SSH是Java企业级开发中广泛应用的一...

    Dwr 表单提交 时间类型

    标题 "Dwr 表单提交 时间类型" 涉及的是Direct Web Remoting (DWR)框架中的一个关键概念,即如何处理表单提交时的时间数据类型。DWR是一种允许JavaScript与服务器端Java代码进行交互的技术,使得Web应用能够实现动态...

Global site tag (gtag.js) - Google Analytics