您好,登錄后才能下訂單哦!
這篇文章主要介紹了使用jquery如何獲取url參數?,具有一定借鑒價值,需要的朋友可以參考下。希望大家閱讀完這篇文章后大有收獲。下面讓小編帶著大家一起了解一下。
方法:首先用“new RegExp("(^|&)"+name+"=([^&]*)(&|$)")”構造一個含有目標參數的正則對象;然后用“location.search.substr(1).match()”匹配目標參數;最后將參數值返回即可。
使用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: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');
完整代碼:
<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參數?內容對大家有幫助,同時也希望大家多多支持億速云,關注億速云行業資訊頻道,遇到問題就找億速云,詳細的解決方法等著你來學習!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。