博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
[开发笔记]-使用jquery获取url及url参数的方法
阅读量:6481 次
发布时间:2019-06-23

本文共 1813 字,大约阅读时间需要 6 分钟。

使用jquery获取url以及使用jquery获取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:33064/WebForm2.aspx?reurl=WebForm1.aspx

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

var xx = getUrlParam('reurl');

明白了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 xx = $.getUrlParam('reurl');

完整代码:

    

 

2014-4-23 修改

今天在用上面的方法获取url中的参数时,url中传递的中文参数在解析的时候无论怎么测试,获取的都是乱码。经过一番调试后发现,我再传递参数时,对汉字编码使用的是 encodeURI ,而上面的方法在解析参数编码时使用的是unescape ,修改为 decodeURI 就可以了。

附: W3School中的介绍:

JavaScript unescape() 函数

定义和用法

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

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

 

说明

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

提示和注释

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

 

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

escape()   unescape()

encodeURI()   decodeURI() 

encodeURIComponent()    decodeURIComponent()  

 

网上找的另一种javascript获取url中参数的方法:

http://www.cnblogs.com/babycool/p/3169058.html
你可能感兴趣的文章
UT-Exynos4412 三星ARM四核旗舰开发平台android4.0体验-13串口功能调试
查看>>
设计模式状态
查看>>
day44-Celery异步分布式
查看>>
Android学习之Android studio TraceView和lint工具的使用具体解释
查看>>
python做var模型的滞后阶数怎么确定_请问关于VAR模型的滞后阶数怎么确定?
查看>>
java多线程理解_三个趣味故事,让你如何理解Java多线程!
查看>>
java 获取温度_Java利用RXTX串口通信工具类获取DS18B20温度传感器的温度值
查看>>
active控件和java脚本_【学习笔记】在原生javascript中使用ActiveX和插件
查看>>
android lua调用java_android lua 在java 中的应用实例
查看>>
java concurrency 线程_JAVA CONCURRENCY EXECUTORS 介绍Java并发处理线程池
查看>>
java equals方法可变_Java性能优化(7):改写equals时遵守通用约定
查看>>
Java怎么输入秒打印出时分_1.java小作业-计算1到100的整合-指定输入多少行输出就打印多少行-打印24小时60分钟每一分钟-重载基础练习-面向java编程初学者...
查看>>
java8 functionalinterface注解_JDK8 新特性 @FunctionalInterface 函数式接口
查看>>
java订单编号工具类_[idmiss-common] Java 工具类之- 顺序订单号的生成
查看>>
php认识正则吗,浅谈PHP正则表达式的一点理解
查看>>
php生成excel到服务器,PHPExcel写入Excel并保存到服务器?
查看>>
PHP限制上次文件只能是图片,php如何控制用户对图片的访问 PHP禁止图片盗链
查看>>
php替换颜色,php Hex RGB颜色值互换的使用
查看>>
PHP的Socket通信之UDP篇,PHP的Socket通信之UDP通信实例
查看>>
php array call,PHP通过_call实现多继承
查看>>