extjs源码分析-(Ext.urlDecode/urlEncode)
2016-04-13 09:49
651 查看
//把json格式转化成url的编码方式
// e.g. Ext.urlEncode({foo: 1, bar: 2}); would return "foo=1&bar=2"
urlEncode: function(o, pre){//o为json对象,pre为前缀
var undef, buf = [], key, e = encodeURIComponent;
for(key in o){
undef = !Ext.isDefined(o[key]);
Ext.each(undef ? key : o[key], function(val, i){
buf.push("&", e(key), "=", (val != key || !undef) ? e(val) : "");
});
}
if(!pre){
buf.shift();
pre = "";
}
return pre + buf.join('');
},
//把URL字符串编码转化成json对象
//Ext.urlDecode("foo=1&bar=2"); // returns {foo: "1", bar: "2"}
//Ext.urlDecode("foo=1&bar=2&bar=3&bar=4", false); // returns {foo: "1", bar: ["2", "3", "4"]}
urlDecode : function(string, overwrite){//string URL参数,overwrite针对同一参数的多个值是否覆盖,false为不覆盖,那就返回这个参数的数组
var obj = {},
pairs = string.split('&'),
d = decodeURIComponent,
name,
value;
Ext.each(pairs, function(pair) {
pair = pair.split('=');
name = d(pair[0]);
value = d(pair[1]);
obj[name] = overwrite || !obj[name] ? value :
[].concat(obj[name]).concat(value);
});
return obj;
}
原文链接: http://lovebeyond.iteye.com/blog/949502
// e.g. Ext.urlEncode({foo: 1, bar: 2}); would return "foo=1&bar=2"
urlEncode: function(o, pre){//o为json对象,pre为前缀
var undef, buf = [], key, e = encodeURIComponent;
for(key in o){
undef = !Ext.isDefined(o[key]);
Ext.each(undef ? key : o[key], function(val, i){
buf.push("&", e(key), "=", (val != key || !undef) ? e(val) : "");
});
}
if(!pre){
buf.shift();
pre = "";
}
return pre + buf.join('');
},
//把URL字符串编码转化成json对象
//Ext.urlDecode("foo=1&bar=2"); // returns {foo: "1", bar: "2"}
//Ext.urlDecode("foo=1&bar=2&bar=3&bar=4", false); // returns {foo: "1", bar: ["2", "3", "4"]}
urlDecode : function(string, overwrite){//string URL参数,overwrite针对同一参数的多个值是否覆盖,false为不覆盖,那就返回这个参数的数组
var obj = {},
pairs = string.split('&'),
d = decodeURIComponent,
name,
value;
Ext.each(pairs, function(pair) {
pair = pair.split('=');
name = d(pair[0]);
value = d(pair[1]);
obj[name] = overwrite || !obj[name] ? value :
[].concat(obj[name]).concat(value);
});
return obj;
}
原文链接: http://lovebeyond.iteye.com/blog/949502
相关文章推荐
- CommonJS,AMD,CMD区别
- 使用Gson进行json数据转换list to json 和json to list
- Gson解析复杂的json数据[转]
- 解析js中( ( ) { } ( ) )的含义
- 上传图片预览JS脚本 Input file图片预览的实现示例
- javaScript对象基础
- C#后台接受前台JSON字符串装换成字典集合处理
- js获取鼠标焦点位置并选中一部分文字
- JavaScript中创建对象的几种方式
- js typeof
- js实现击购物物品抛物线到购物车
- [Javascript] JavaScript Array Methods in Depth - push
- js监听textarea文本域变化使高度自适应
- js中获取时间new Date()详细介绍
- 通过js修改html的标签属性
- JS 执行环境与作用域链
- JS中__proto__与prototype的关系
- web day4 javascript&DOM
- javascript杂谈 半整合半原创篇
- Javascript之自定义事件