【jQuery】获取url参数及url加参数的方法

1、jquery 获取 url 很简单,代码如下:

window.location.href;

其实只是用到了 javascript 的基础的 window 对象,并没有用 jquery 的知识。

2、jquery 获取 url 参数比较复杂,要用到正则表达式,所以学好 javascript 正则式多么重要的事情

首先看看单纯的通过 javascript 是如何来获取 url 中的某个参数:

//获取url中的参数
function getUrlParam(name) {
 var reg = new RegExp("(^|&)" + name + "=([^&]*)(&|$)"); //构造一个含有目标参数的正则表达式对象
 var r = window.location.search.substr(1).match(reg); //匹配目标参数
 if (r != null) return unescape(r[2]); return null; //返回参数值
}

通过这个函数传递 url 中的参数名就可以获取到参数的值,比如 url 为

http://localhost:8080/works?worksid=1

我们要获取 worksid 的值,可以这样写:

var worksid = getUrlParam('worksid');

明白了 javascript 获取 url 参数的方法,我们可以通过这个方法为 jquery 扩展一个方法来通过 jquery 获取 url 参数,下面的代码为 jquery 扩展了一个 getUrlParam() 方法

(function ($) {
  $.getUrlParam = function (name) {
   var reg = new RegExp("(^|&)" + name + "=([^&]*)(&|$)");
   var r = window.location.search.substr(1).match(reg);
   if (r != null) return unescape(r[2]); return null;
  }
 })(jQuery);

为 jquery 扩展了这个方法了之后我们就可以通过如下方法来获取某个参数的值了:

var worksid = $.getUrlParam('worksid');

用上面的方法获取 url 中的参数时,url 中传递的中文参数在解析的时候无论怎么测试,获取的都是乱码。原因是在传递参数时,对汉字编码使用的是 encodeURI ,而上面的方法在解析参数编码时使用的是 unescape,修改为 decodeURI 就可以了。
综上: javascript对参数编码解码方法要一致:
escape() unescape()
encodeURI() decodeURI()
encodeURIComponent() decodeURIComponent()

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值