dwr实现三联动

[b]web.xml配置:[/b]
<?xml version="1.0" encoding="UTF-8"?>
<web-app id="WebApp_ID" version="2.4"
xmlns="http://java.sun.com/xml/ns/j2ee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd">
<display-name>DWR</display-name>
<servlet>
<servlet-name>dwr-invoker</servlet-name>
<servlet-class>uk.ltd.getahead.dwr.DWRServlet</servlet-class>
<init-param>
<param-name>debug</param-name>
<param-value>true</param-value>
</init-param>
</servlet>

<servlet-mapping>
<servlet-name>dwr-invoker</servlet-name>
<url-pattern>/dwr/*</url-pattern>
</servlet-mapping>

<welcome-file-list>
<welcome-file>index.html</welcome-file>
<welcome-file>index.htm</welcome-file>
<welcome-file>index.jsp</welcome-file>
<welcome-file>default.html</welcome-file>
<welcome-file>default.htm</welcome-file>
<welcome-file>default.jsp</welcome-file>
</welcome-file-list>
</web-app>

[b]dwr.xml文件:[/b]
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE dwr PUBLIC "-//GetAhead Limited//DTD Direct Web Remoting 2.0//EN" "http://getahead.org/dwr/dwr20.dtd">
<dwr>
<allow>
<create creator="new" javascript="AjaxDAO">
<param name="class" value="com.soft.dwr.AjaxDAO" />
</create>
</allow>
</dwr>


java类:
DataSourceFactory.java
package com.soft.dwr;


import org.apache.commons.dbcp.BasicDataSource;


public class DataSourceFactory {

/**
* @param args
*/
static BasicDataSource ds;//apatch的连接池
public static BasicDataSource getDataSource(){
if(ds==null){
ds=new BasicDataSource();
ds.setDriverClassName("com.microsoft.jdbc.sqlserver.SQLServerDriver");
ds.setUrl("jdbc:microsoft:sqlserver://localhost:1433;DatabaseName=DWR");
ds.setUsername("sa");
ds.setPassword("");
ds.setMaxActive(5);
}
return ds;
}

}

AjaxDao.java
package com.soft.dwr;

import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.HashMap;
import java.util.Map;

public class AjaxDAO {

private final String COUNTRY = "select * from country";
private final String PROVINCE = "select * from province where countryid=?";
private final String CITY="select * from city where provinceid=?";


public Map getProvince(int id) {
Map<String, String> map = new HashMap<String, String>();
Connection con;
try {
con = DataSourceFactory.getDataSource().getConnection();
PreparedStatement ps = con.prepareStatement(PROVINCE);
ps.setInt(1, id);
ResultSet rs = ps.executeQuery();
while (rs.next()) {
map.put(new Integer(rs.getInt(1)).toString(), rs.getString(2));
}
if(rs!=null){rs.close()}
if(ps!=null){ps.close()}
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}

return map;

}

public Map getCountry() {
Map<String, String> map = new HashMap<String, String>();
Connection con;
try {
con = DataSourceFactory.getDataSource().getConnection();
PreparedStatement ps = con.prepareStatement(COUNTRY);
ResultSet rs = ps.executeQuery();
while (rs.next()) {
map.put(new Integer(rs.getInt(1)).toString(), rs.getString(2));
}
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}

return map;

}

public Map getCity(int id) {
Map<String, String> map = new HashMap<String, String>();
Connection con;
try {
con = DataSourceFactory.getDataSource().getConnection();
PreparedStatement ps = con.prepareStatement(CITY);
ps.setInt(1, id);
ResultSet rs = ps.executeQuery();
while (rs.next()) {
map.put(new Integer(rs.getInt(1)).toString(), rs.getString(2));
}
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}

return map;

}
}

[b]页面:[/b]
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Insert title here</title>
<script type='text/javascript' src='/ajax/dwr/interface/AjaxDAO.js'></script>
<script type='text/javascript' src='/ajax/dwr/engine.js'></script>
<script type='text/javascript' src='/ajax/dwr/util.js'></script>

<script>
function init(){

AjaxDAO.getCountry(callback);
}
function callback(data){

var country=document.getElementById("country");
DWRUtil.removeAllOptions(country);
DWRUtil.addOptions(country,{'':'请选择'});
DWRUtil.addOptions(country,data);
}

function getProvince(value){
if(value!='')
AjaxDAO.getProvince(parseInt(value),setProvince);
}

function setProvince(data){
var province=document.getElementById("province");
DWRUtil.removeAllOptions(province);
DWRUtil.addOptions(province,{'':'请选择'});
DWRUtil.addOptions(province,data);
}

function getCity(value){
if(value!='')
AjaxDAO.getCity(parseInt(value),setCity);
}

function setCity(data){
var city=document.getElementById("city");
DWRUtil.removeAllOptions(city);
DWRUtil.addOptions(city,{'':'请选择'});
DWRUtil.addOptions(city,data);
}

</script>
</head>
<body onload="init()" >
<select id="country" onchange="getProvince(this.value)">
</select>
<select id="province" onchange="getCity(this.value)">
</select>
<select id="city">
</select>
</body>
</html>

关于数据库自己设置:
内容概要:本文档主要展示了C语言中关于字符串处理、指针操作以及动态内存分配的相关代码示例。首先介绍了如何实现键值对(“key=value”)字符串的解析,包括去除多余空格和根据键获取对应值的功能,并提供了相应的测试用例。接着演示了从给定字符串中分离出奇偶位置字符的方法,并将结果分别存储到两个不同的缓冲区中。此外,还探讨了常量(const)修饰符在变量和指针中的应用规则,解释了不同类型指针的区别及其使用场景。最后,详细讲解了如何动态分配二维字符数组,并实现了对这类数组的排序与释放操作。 适合人群:具有C语言基础的程序员或计算机科学相关专业的学生,尤其是那些希望深入理解字符串处理、指针操作以及动态内存管理机制的学习者。 使用场景及目标:①掌握如何高效地解析键值对字符串并去除其中的空白字符;②学会编写能够正确处理奇偶索引字符的函数;③理解const修饰符的作用范围及其对程序逻辑的影响;④熟悉动态分配二维字符数组的技术,并能对其进行有效的排序和清理。 阅读建议:由于本资源涉及较多底层概念和技术细节,建议读者先复习C语言基础知识,特别是指针和内存管理部分。在学习过程中,可以尝试动手编写类似的代码片段,以便更好地理解和掌握文中所介绍的各种技巧。同时,注意观察代码注释,它们对于理解复杂逻辑非常有帮助。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值