转自:点击打开链接

现在的js框架将ajax请求封装得非常简单,例如下面:

  1. $.ajax({
  2. type: "POST",
  3. url: "some.php",
  4. data: { name: "John", location: "Boston" }
  5. }).done(function( msg ) {
  6. alert( "Data Saved: " + msg );
  7. });

上面是基于jQuery框架的一段ajax请求代码,使用了POST请求方式
但在某些场景中我们还是得使用GET方式,并且需要拼出请求参数,比如window.open时,a标签的href等等.像这种拼接字符串的代码很容易发生错误,比如要将一个对象的所有属性和值拼接为URL的请求参数,我们可能需要这样:

  1. var params = '';
  2. params += 'key1='+obj.key1;
  3. params += 'key2='+obj.key2;
  4. params += 'key3='+obj.key3;
  5. params += 'key4='+obj.key4;
  6. ...


不用说太多,痛苦啊,就像苦力,一点也体会不到程序员高大上的感觉.或许,我们可以这样

  1. var params = urlEncode(obj);

既然这样,这是怎么实现的呢?先看一看网上一哥们基于jQuery的实现方案

  1. var parseParam=function(param, key){
  2. var paramStr="";
  3. if(param instanceof String||param instanceof Number||param instanceof Boolean){
  4. paramStr+="&"+key+"="+encodeURIComponent(param);
  5. }else{
  6. $.each(param,function(i){
  7. var k=key==null?i:key+(param instanceof Array?"["+i+"]":"."+i);
  8. paramStr+='&'+parseParam(this, k);
  9. });
  10. }
  11. return paramStr.substr(1);
  12. };
  1. //test
  2. var obj={name:'tom','class':{className:'class1'},classMates:[{name:'lily'}]};
  3. parseParam(obj);
  4. //output: "name=tom&class.className=class1&classMates[0].name=lily"
  5. parseParam(obj,'stu');
  6. //output: "stu.name=tom&stu.class.className=class1&stu.classMates[0].name=lily"

引用自刘家华 http://www.oschina.net/code/snippet_139242_7584

由于是这段代码本身并不算多,为了增强其通用性,我使用了原生Javascript重写了该方法,如下:

  1. /**
  2. * param 将要转为URL参数字符串的对象
  3. * key URL参数字符串的前缀
  4. * encode true/false 是否进行URL编码,默认为true
  5. *
  6. * return URL参数字符串
  7. */
  8. var urlEncode = function (param, key, encode) {
  9. if(param==null) return '';
  10. var paramStr = '';
  11. var t = typeof (param);
  12. if (t == 'string' || t == 'number' || t == 'boolean') {
  13. paramStr += '&' + key + '=' + ((encode==null||encode) ? encodeURIComponent(param) : param);
  14. } else {
  15. for (var i in param) {
  16. var k = key == null ? i : key + (param instanceof Array ? '[' + i + ']' : '.' + i);
  17. paramStr += urlEncode(param[i], k, encode);
  18. }
  19. }
  20. return paramStr;
  21. };
  22. var obj={name:'tom','class':{className:'class1'},classMates:[{name:'lily'}]};
  23. console.log(urlEncode(obj));
  24. //output: &name=tom&class.className=class1&classMates[0].name=lily
  25. console.log(urlEncode(obj,'stu'));
  26. //output: &stu.name=tom&stu.class.className=class1&stu.classMates[0].name=lily

JS对象转URL参数(原生JS和jQuery两种方式)的更多相关文章

  1. iOS 通过URL网络获取XML数据的两种方式

    转载于:http://blog.csdn.net/crayondeng/article/details/8738768 下面简单介绍如何通过url获取xml的两种方式. 第一种方式相对简单,使用NSD ...

  2. 常见浏览器的宽高代码写法!有原生JavaScript和jquery两种写法-------------------------------以及我的个人网站

    我的个人网站 点击链接!欢迎大家访问 下面是网页一些常见的宽高的获取.........这是原生的写法(JavaScript) 网页可见区域宽: document.body.clientWidth 网页 ...

  3. Python与数据库[2] -> 关系对象映射/ORM[2] -> 建立声明层表对象的两种方式

    建立声明层表对象的两种方式 在对表对象进行建立的时候,通常有两种方式可以完成,以下是两种方式的建立过程对比 首先导入需要的模块,获取一个声明层 from sqlalchemy.sql.schema i ...

  4. Python与数据库 sqlalchemy 建立声明层表对象的两种方式

    在对表对象进行建立的时候,通常有两种方式可以完成,以下是两种方式的建立过程对比 首先导入需要的模块,获取一个声明层 1 from sqlalchemy.sql.schema import Table, ...

  5. js_html_input中autocomplete="off"在chrom中失效的解决办法 使用JS模拟锚点跳转 js如何获取url参数 C#模拟httpwebrequest请求_向服务器模拟cookie发送 实习期学到的技术(一) LinqPad的变量比较功能 ASP.NET EF 使用LinqPad 快速学习Linq

    js_html_input中autocomplete="off"在chrom中失效的解决办法 分享网上的2种办法: 1-可以在不需要默认填写的input框中设置 autocompl ...

  6. 原生js更改css样式的两种方式

    下面我给大家介绍的是原生js更改CSS样式的两种方式: 1通过在javascript代码中的node.style.cssText="css表达式1:css表达式2:css表达式3  &quo ...

  7. JS中访问对象的两种方式区别

    可以使用下面两种方式访问对象的属性和方法 1.对象名.属性名 对象名.方法名() 2.对象名["属性名"] 对象名["方法名"]() var obj = { n ...

  8. 【javascript】原生js更改css样式的两种方式

    下面我给大家介绍的是原生js更改CSS样式的两种方式: 1通过在javascript代码中的node.style.cssText="css表达式1:css表达式2:css表达式3  &quo ...

  9. js实现页面跳转的两种方式

      CreateTime--2017年8月24日08:13:52Author:Marydon js实现页面跳转的两种方式 方式一: window.location.href = url 说明:我们常用 ...

随机推荐

  1. 以太坊(二)安装Solidity编译器

    官方地址:https://solidity.readthedocs.io/en/develop/installing-solidity.html 推荐使用  remix   快速学习solidity  ...

  2. Java-Runoob-面向对象:Java 多态

    ylbtech-Java-Runoob-面向对象:Java 多态 1.返回顶部 1. Java 多态 多态是同一个行为具有多个不同表现形式或形态的能力. 多态就是同一个接口,使用不同的实例而执行不同操 ...

  3. bytes数据类型和字符串的编码解码,三元运算,进制互换

    三元运算 如果这个条件成立就存这个值,如果那个条件成立就存那个值. 进制 bytes类型,字节数据类型也就是二进制类型,这个是python3专有数据类型,在python2里跟字符串是一个类型,也就是p ...

  4. MariaDB主从异步复制详解

    一 异步复制(Asynchronous replication) 1.MariaDB本身支持单向的.异步的复制.异步复制意味着在把数据从一台机器拷贝到另一台机器时有一个延时,最重要的是这意味着当应用系 ...

  5. Java中RMI远程调用demo

    Java远程方法调用,即Java RMI(Java Remote Method Invocation),一种用于实现远程过程调用的应用程序编程接口.它使客户机上运行的程序可以调用远程服务器上的对象.远 ...

  6. servlet对应.net中的http上下文

    java中的servlet在.net中其实就是http上下文.

  7. C++ primer plus

    给cout指针,默认打印指针地址,但如果指针的类型的char*,将打印指向的字符串,如果要显示的是字符串的地址,将指针强制转换为另一种类型 char* animal cout << ani ...

  8. 同源策略、CORS

    一.同源策略 同源策略(Same origin policy) 是一种约定, 它是浏览器最核心也是最基本的安全功能 , 如果缺少了同源策略, 则浏览器的正常功能可能都会受影响 , 可以说web是构建在 ...

  9. ztree--插件实现增删改查demo(完整版)

    ztree--插件实现增删改查demo(完整版) var setting = {                 async: {                     enable: true,  ...

  10. 部署ASP.net MVC程序到IIS

    转:http://www.cnblogs.com/piyeyong/archive/2012/08/15/2640004.html 在网上找到一个table,列举了不同的操作系统对应的IIS版本以及配 ...