使用jquery怎么获取url参数?


本文摘自PHP中文网,作者青灯夜游,侵删。

方法:首先用“new RegExp("(^|&)"+name+"=([^&]*)(&|$)")”构造一个含有目标参数的正则对象;然后用“location.search.substr(1).match()”匹配目标参数;最后将参数值返回即可。

本教程操作环境:windows7系统、jquery3.2.1版,该方法适用于所有品牌电脑。

相关推荐:《jQuery教程》

使用jquery获取url及url参数的方法

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

1

window.location.href;

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

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

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

1

2

3

4

5

6

//获取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:33064/WebForm2.aspx?reurl=WebForm1.aspx

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

1

var xx = getUrlParam('reurl');

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

1

2

3

4

5

6

7

(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扩展了这个方法了之后我们就可以通过如下方法来获取某个参数的值了:

1

var xx = $.getUrlParam('reurl');

完整代码:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

<script type="text/javascript">

        $(function () {

 

            //方法二:

            (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);

 

            //方法二:

            var xx = $.getUrlParam('reurl');

 

            //方法一:

            // var xx = getUrlParam('reurl');

 

 

            alert(xx);

 

        });

 

        //方法一:

        //获取url中的参数

        function getUrlParam(name) {

            var reg = new RegExp("(^|&)" + name + "=([^&]*)(&|$)"); //构造一个含有目标参数的正则表达式对象

            var r = window.location.search.substr(1).match(reg);  //匹配目标参数

            if (r != null) return encodeURI(r[2]); return null; //返回参数值

        }

 

 

 </script>

JavaScript unescape() 函数

定义和用法

unescape() 函数可对通过 escape() 编码的字符串进行解码。

参数描述
string必需。要解码或反转义的字符串。

说明

该函数的工作原理是这样的:通过找到形式为 %xx 和 %uxxxx 的字符序列(x 表示十六进制的数字),用 Unicode 字符 \u00xx 和 \uxxxx 替换这样的字符序列进行解码。

提示和注释

注释:ECMAScript v3 已从标准中删除了 unescape() 函数,并反对使用它,因此应该用 decodeURI() 和 decodeURIComponent() 取而代之。

综上: javascript对参数编码解码方法要一致:

  • escape()和unescape()

  • encodeURI()和decodeURI()

  • encodeURIComponent()和decodeURIComponent()

更多编程相关知识,请访问:编程视频课程!!

以上就是使用jquery怎么获取url参数?的详细内容,更多文章请关注木庄网络博客

相关阅读 >>

$.cookie is not a function

jq怎么设置css样式

jQuery怎么去除css样式?

jQuery click()和onclick()区别是什么

如何解决jQuery on 不生效问题

怎么用cdn引用jQuery

jQuery中的美元符号$有什么作用

jQuery如何使用if判断标签内容不为空

jQuery怎么判断radio是否选中

jQuery 怎么写if

更多相关阅读请进入《jQuery》频道 >>




打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...