最近项目中须要作一个关于批量删除的功能,删除条件有多个,须要从页面所有传给后台服务器程序,单个的删除,能够拼接参数给url,服务器端获取参数后执行删除操做便可。可是批量删除多个,参数会不少,传递就有些麻烦。固然有一种比较常见的解决方法,是使用逗号、下划线、或者分号分割,而后传到后台拆分后再进行操做,这种方法须要前台拼接,后台解析,稍显繁复且容易出错。对于搞JAVA程序的我来讲,显得不是很面向对象。因而很天然的想到了使用json字符串进行传递数据,具体步骤以下:一、先把想要传递的参数封装成js对象,代码样例以下:java
var params = [];node
var param = {};ajax
param["aaa"] = "a";数据库
param["bbb"] = true;json
param["ccc"] = 2;浏览器
params.push(param);服务器
二、接下来把js对象转成json字符串,java培训机构中比较常见的作法是使用JSON.stringfy(),尝试一番以后发现IE8浏览器并不支持(该方法对谷歌、火狐、以及IE9以上版本浏览器完美支持),而咱们当前的产品只支持IE浏览器,转而求救谷歌百度,找到一个比较通用的js方法,代码以下:url
function obj2Str(obj) {对象
switch (typeof (obj)) {字符串
case 'object':
var ret = [];
if (obj instanceof Array) {
for (var i = 0, len = obj.length; i < len; i++)
{
ret.push(obj2Str(obj[i]));
}
return '[' + ret.join(',') + ']';
}
else if (obj instanceof RegExp)
{
return obj.toString();
}
else
{
for (var a in obj)
{
ret.push(a + ':' + obj2Str(obj[a]));
}
return '{' + ret.join(',') + '}';
}
case 'function':
return 'function() {}';
case 'number':
return obj.toString();
case 'string':
return '"' + obj.replace(/(\\|\")/g, '\\$1').replace(/\n|\r|\t/g, function (a)
{
return ('\n' == a) ? '\\n' : ('\r' == a) ? '\\r' : ('\t' == a) ? '\\t' : '';
}) + '"';
case 'boolean':
return obj.toString();
default:
return obj.toString();
}
}
三、前台封装好之后,使用ajax请求到后台,JAVA解析json字符串的方法很多,能够在网上找写好的方法,固然也可使用json-lib-xxx.jar,这个jar包在项目中应用很普遍,LZ上一家公司就使用其作了大量json转化工做,使用方法以下:
JSONArray jsonArray = JSONArray.fromObject(jsonStr);
List<Map> cmdList = (List<Map>)JSONArray.toCollection(jsonArray, Map.class);
四、经过内置方法转化成集合,再传递到ibatis或者本身使用的数据库持久层进行处理便可。