免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1073 | 回复: 0
打印 上一主题 下一主题

AJAX实例:据邮政编码自动完成城市和地址信息 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2006-10-23 14:55 |只看该作者 |倒序浏览


AJAX据邮政编码自动完成城市和地址信息     
     
     
描述:在注册或购物车结帐的时候,需要用户填入个人资料,这个环节可以简练一下,我们只需客人填入邮政编码,然后就根据这个邮政编码,自动从数据库中取出相应的省,市等地址信息。
     
这样既可以减少客户的输入,增加客户体验,又可以减少由于资料输入而产生的错误。
     
实现:
     
     
     
     
HTML
function createRequestObject() {
var ro;
var browser = navigator.appName;
if(browser == "Microsoft Internet Explorer"){
ro = new ActiveXObject("Microsoft.XMLHTTP");
}else{
ro = new XMLHttpRequest();
}
return ro;
}
   
var http = createRequestObject();
   
function sndReq(zip) {
http.open('get', 'zipcode.php?zip='+zip);
http.onreadystatechange = handleResponse;
http.send(null);
}
   
function handleResponse() {
if(http.readyState == 4){
var response = http.responseText;
var update = new Array();
   
if(response.indexOf('|' != -1)) {
update = response.split('|');
document.getElementById("city").value = update[0];
document.getElementById("state").value = update[1];
}
}
}
Enter A United States Zipcode, Then Tab
Enter Zipcode:
City:
State:
     
以上是客户输入页面,下面是服务端的处理页面'zipcode.php
     
     
     
     
     
当客户输入一个POSTCODE后,zipcode.php就接收到它,然后进行从数据表中取出对应的资料,再按一定的格式返回给客户端(此处是以 | 分隔)。最后客户端接收返回的资料,显示在页面上。
     
     
     
     
if(response.indexOf('|' != -1)) {
update = response.split('|');
document.getElementById("city").value = update[0];
document.getElementById("state").value = update[1];
}
     
     
     
描述:在注册或购物车结帐的时候,需要用户填入个人资料,这个环节可以简练一下,我们只需客人填入邮政编码,然后就根据这个邮政编码,自动从数据库中取出相应的省,市等地址信息。
     
这样既可以减少客户的输入,增加客户体验,又可以减少由于资料输入而产生的错误。
     
实现:
     
     
     
     
HTML
function createRequestObject() {
var ro;
var browser = navigator.appName;
if(browser == "Microsoft Internet Explorer"){
ro = new ActiveXObject("Microsoft.XMLHTTP");
}else{
ro = new XMLHttpRequest();
}
return ro;
}
   
var http = createRequestObject();
   
function sndReq(zip) {
http.open('get', 'zipcode.php?zip='+zip);
http.onreadystatechange = handleResponse;
http.send(null);
}
   
function handleResponse() {
if(http.readyState == 4){
var response = http.responseText;
var update = new Array();
   
if(response.indexOf('|' != -1)) {
update = response.split('|');
document.getElementById("city").value = update[0];
document.getElementById("state").value = update[1];
}
}
}
Enter A United States Zipcode, Then Tab
Enter Zipcode:
City:
State:
     
以上是客户输入页面,下面是服务端的处理页面'zipcode.php
     
     
     
     
     
当客户输入一个POSTCODE后,zipcode.php就接收到它,然后进行从数据表中取出对应的资料,再按一定的格式返回给客户端(此处是以 | 分隔)。最后客户端接收返回的资料,显示在页面上。
     
     
     
     
if(response.indexOf('|' != -1)) {
update = response.split('|');
document.getElementById("city").value = update[0];
document.getElementById("state").value = update[1];
}
     

     
FROM:http://www.pg888.com/hint/01/04/531b9b9a0b0549f0010b057269a30104.html


本文来自ChinaUnix博客,如果查看原文请点:http://blog.chinaunix.net/u/10346/showart_189064.html
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP