热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

ajax操作json实现动态下拉列表

先给出一段兼容浏览器的获取AJAX对象的javascript函数functiongetXmlHttp(){varXmlhttpnull;try{XmlhttpnewActiveXObject(MSXML2.XMLHTTP);}catch(e){try{XmlhttpnewActiveXObject(Microsoft.

先给出一段兼容浏览器的获取AJAX对象的Javascript函数

function getXmlHttp(){

var Xmlhttp=null;

try{

Xmlhttp = new ActiveXObject("MSXML2.XMLHTTP");

}catch(e){
try{Xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");

}catch(E){

Xmlhttp = false;}
}
if((!Xmlhttp) && (typeof(XMLHttpRequest)!= 'undefined') ) {

Xmlhttp = new XMLHttpRequest();

}

return Xmlhttp;
}

使用方法 var xmlhttp = getXmlHttp();

在很多的ajax范例中,开发者都是用xmlhttp从服务器端获得一个xml数据,然后转换成Javascript可触及的对象,再用js绘制到document中.但我觉得这并非唯一选项,我甚至觉得是多此一举!为什么不直接传递js对象呢?在我开发的系统中,xmlhttp从服务器上获得的是代表js对象的字符串.假如我要传送一个人员列表,我会在服务器上输出:
[{id:1,name:"name1"},{id:2,name:"name2"},{id:3,name:"name3"}]

然后在浏览器上用js获得这个字符串所代表的对象:
var returned = xmlhttp.responseText;
var obj = eval(returned );
接着,你就可以这样访问:
var person1 = obj[0]; var person2 = obj[1];
alert(person1.id);
alert(person1.name);

这样做比传递xml文档直接一些,不必通过转换可以让js直接访问数据.

ajax操作json举例: 使用JSON来做数据传输的动态下拉列表

动态下拉列表的原理其实很简单的,当某一下拉列表触发了onchange事件,然后使用AJAX在后台向服务器异步请求数据,最后将服务器返回的数据进行解析后动态添加到指定的select上即可!

首先来看后台的数据输出,我们假设服务器传送给客户段的JSON数据格式为如下:

{
"options" : [
{"value" : 值,"text" : 文本},
{"value" : 值,"text" : 文本},
{"value" : 值,"text" : 文本}
]
}

其中options是整个JSON对象的标识符,它是一个数组,该数组中的每一个值表示一个select中的option,当然该值也是一个对象了,有两个属性,一个是value,一个是text,分别对应option中的value和显示的text值.

有了数据格式,那么客户端和服务器端进行交流就方便很多了.我们来先写客户端的JS方法.这里我是提供一个静态的实用类Select,专门针对select元素的操作方法,如下:


function Select(){};


Select.create = function( selectId, json ) {
Select.clear(selectId);
Select.add(selectId, json);
};

Select.add = function(selectId,json) {
try {
if (!json.options) return;
for (var i = 0; i Select.addOption(selectId,json.options[i].value,json.options[i].text);
}
} catch (ex) {
base.alert('设置select错误:指定的JSON对象不符合Select对象的解析要求!');
}
};

Select.createOption = function( value, text) {
var opt = document.createElement_x('option');
opt.setAttribute('value', value);
opt.innerHTML = text;
return opt;
};

Select.addOption = function( selectId, value, text) {
var opt = Select.createOption(value, text);
$(selectId).appendChild(opt);
return opt;
};

Select.getSelected = function( selectId) {
var slt = $(selectId);
if (!slt) return null;
if (slt.type.toLowerCase() == "select-multiple") {
var len = Select.len(selectId);
var result = [];
for (var i = 0; i if (slt.options[i].selected) result.push(slt.options[i]);
}
return result.length > 1 ? result : (result.length == 0 ? null : result[0]);
} else {
var index = $(selectId).selectedIndex;
return $(selectId).options[index];
}
};

Select.select = function( selectId, index) {
var slt = $(selectId);
if (!slt) return false;
for (var i = 0; i if (index == i) {
slt.options[i].setAttribute("selected", "selected");
return true;
}
}
return false;
};

Select.selectAll = function( selectId) {
var len = Select.len(selectId);
for (var i = 0; i };

Select.len = function( selectId) {
return $(selectId).options.length;
};

Select.clear = function( selectId, iterator) {
if (typeof(iterator) != 'function') {
$(selectId).length = 0;
} else {
var slt = $(selectId);
for (var i = slt.options.length - 1; i >= 0; i --) {
if (iterator(slt.options[i]) == true) slt.removeChild(slt.options[i]);
}
}
};

Select.copy = function( srcSlt, targetSlt, iterator) {
var s = $(srcSlt), t = $(targetSlt);
for (var i = 0; i if (typeof(iterator) == 'function') {
if (iterator(s.options[i], $(targetSlt).options) == true) {
t.appendChild(s.options[i].cloneNode(true));
}
} else {
t.appendChild(s.options[i].cloneNode(true));
}
}
};

那么在回调方法中就可以只要来调用:

……
var jsOnString= xmlHttp.responeText; // 获取服务器返回的json字符串
var jsOnObj= null;
try {
jsOnObj= eval_r('(' + jsonString + ')'); // 将json字符串转换成对象
} catch (ex) {
return null;
}
Select.create("你的select的ID", jsonObj); // 执行option的添加
……

在Select中提供了很多实用的JS方法来方便操作select对象,我们这里只使用其中的create方法.客户端有了JS,我们现在服务器端的字符串输出json数据.

这里我们用到了JSONLib库,该库可以很方便的来从现有的javaBean或其他集合对象中来转换成json字符串.我们这里也提供一个公用类如下:

package common.utils.json;

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

import net.sf.json.JSONArray;
import net.sf.json.JSONObject;

import org.apache.commons.beanutils.BeanUtils;
import org.apache.log4j.Logger;


public class SelectJSON
{


private static final Logger log = Logger.getLogger(SelectJSON.class);


public static String fromMap(Map map)
{
Iterator it = map.keySet().iterator();
JSONArray optiOns= new JSONArray();
while (it.hasNext()) {
JSONObject option = new JSONObject();
String key = (String)it.next();
option.put("value", key);
option.put("text", map.get(key));
options.put(option);
}
JSONObject result = new JSONObject();
result.put("options", options.toString());
return result.toString();
}


public static String fromList(List list, String valueProp, String textProp)
{
JSONArray optiOns= new JSONArray();
try {
for (Object obj : list) {
JSONObject option = new JSONObject();
String value = BeanUtils.getProperty(obj, valueProp);
String text = BeanUtils.getProperty(obj, textProp);
option.put("value", value);
option.put("text", text);
options.put(option);
}
} catch (Exception ex) {
throw new RuntimeException(ex);
}
JSONObject result = new JSONObject();
result.put("options", options.toString());
return result.toString();
}

public static void main(String[] args)
{
// map 测试
Map tt = new HashMap();
tt.put("value1", "text1");
tt.put("value2", "text2");
tt.put("value3", "text3");
log.info(SelectJSON.fromMap(tt));
}
}

在类SelectJSON中提供了两个方法,一个是从map中来获取并转换成json字符串,还一个就是从list中的对象来获取,这个方法需要使用BeanUtils工具来辅助获取JavaBean对象中的指定属性.当然了,你可以可以写其他方便发辅助方法来达到这样的效果.

比如我们在上面的SelectJSON类中的测试,会输出:

{"options":[{"value":"value1","text":"text1"},{"value":"value2","text":"text2"},{"value":"value3","text":"text3"}]}

然后我们再调用上面提到的JS类Select进行操作就可以了,注意,在使用Select类进行操作前,比如先转换服务器返回的字符串为js对象,即使用eval来执行返回字符串即可!


推荐阅读
  • 本文将详细介绍如何在ThinkPHP6框架中实现多数据库的部署,包括读写分离的策略,以及如何通过负载均衡和MySQL同步技术优化数据库性能。 ... [详细]
  • 本文详细介绍如何利用已搭建的LAMP(Linux、Apache、MySQL、PHP)环境,快速创建一个基于WordPress的内容管理系统(CMS)。WordPress是一款流行的开源博客平台,适用于个人或小型团队使用。 ... [详细]
  • 本文探讨了如何通过WebBrowser控件在用户点击输入框时自动显示图片验证码。该过程可能涉及JavaScript事件的触发与响应。 ... [详细]
  • 本文探讨了浏览器的同源策略限制及其对 AJAX 请求的影响,并详细介绍了如何在 Spring Boot 应用中优雅地处理跨域请求,特别是当请求包含自定义 Headers 时的解决方案。 ... [详细]
  • 本文探讨了 RESTful API 和传统接口之间的关键差异,解释了为什么 RESTful API 在设计和实现上具有独特的优势。 ... [详细]
  • 本文探讨了在不使用服务器控件的情况下,如何通过多种方法获取并修改页面中的HTML元素值。除了常见的AJAX方式,还介绍了其他可行的技术方案。 ... [详细]
  • 解决JAX-WS动态客户端工厂弃用问题并迁移到XFire
    在处理Java项目中的JAR包冲突时,我们遇到了JaxWsDynamicClientFactory被弃用的问题,并成功将其迁移到org.codehaus.xfire.client。本文详细介绍了这一过程及解决方案。 ... [详细]
  • 本文探讨了在通过 API 端点调用时,使用猫鼬(Mongoose)的 findOne 方法总是返回 null 的问题,并提供了详细的解决方案和建议。 ... [详细]
  • 探讨如何真正掌握Java EE,包括所需技能、工具和实践经验。资深软件教学总监李刚分享了对毕业生简历中常见问题的看法,并提供了详尽的标准。 ... [详细]
  • 本文介绍了多个关于JavaScript的书籍资源、实用工具和编程实例,涵盖从入门到进阶的各个阶段,帮助读者全面提升JavaScript编程能力。 ... [详细]
  • 本文详细介绍了如何利用Go语言和WebSockets技术构建一个高效的实时聊天系统。随着网络应用的日益复杂化,实时交互成为了提升用户体验的关键要素之一。通过本指南,开发者可以学习到最新的技术和最佳实践。 ... [详细]
  • 理解文档对象模型(DOM)
    本文介绍了文档对象模型(DOM)的基本概念,包括其作为HTML文档的节点树结构,以及如何通过JavaScript操作DOM来实现网页的动态交互。 ... [详细]
  • 本文将介绍如何利用Python爬虫技术抓取国内主流在线学习平台的数据,并以51CTO学院为例,进行详细的技术解析和实践操作。 ... [详细]
  • 深入分析十大PHP开发框架
    随着PHP技术的发展,各类开发框架层出不穷,成为了开发者们热议的话题。本文将详细介绍并对比十款主流的PHP开发框架,旨在帮助开发者根据自身需求选择最合适的工具。 ... [详细]
  • Microsoft即将发布WPF/E的CTP(Community Technology Preview)和SDK,标志着RIA(Rich Internet Application)技术的新里程碑。更多详情及下载链接请参见MSDN官方页面。 ... [详细]
author-avatar
婉婷雅铃43
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有