js如何準(zhǔn)確獲取當(dāng)前頁面url網(wǎng)址信息

在WEB開發(fā)中纫塌,時常會用到j(luò)avascript來獲取當(dāng)前頁面的url網(wǎng)址信息桶良,在這里是我的一些獲取url信息的小總結(jié)嗜侮。

下面我們舉例一個URL焊虏,然后獲得它的各個組成部分:http://i.cnblogs.com/EditPosts.aspx?opt=1


1淡喜、window.location.href(設(shè)置或獲取整個 URL 為字符串)

var test = window.location.href;

alert(test);

返回:http://i.cnblogs.com/EditPosts.aspx?opt=1

2、window.location.protocol(設(shè)置或獲取 URL 的協(xié)議部分)

var test = window.location.protocol;

alert(test);

返回:http:

3诵闭、window.location.host(設(shè)置或獲取 URL 的主機(jī)部分)

var test = window.location.host;

alert(test);

返回:i.cnblogs.com

4炼团、window.location.port(設(shè)置或獲取與 URL 關(guān)聯(lián)的端口號碼)

var test = window.location.port;

alert(test);

返回:空字符(如果采用默認(rèn)的80端口(update:即使添加了:80),那么返回值并不是默認(rèn)的80而是空字符)

5疏尿、window.location.pathname(設(shè)置或獲取與 URL 的路徑部分(就是文件地址))

var test = window.location.pathname;

alert(test);

返回:/EditPosts.aspx

6瘟芝、window.location.search(設(shè)置或獲取 href 屬性中跟在問號后面的部分)

var test = window.location.search;

alert(test);

返回:?opt=1

PS:獲得查詢(參數(shù))部分,除了給動態(tài)語言賦值以外褥琐,我們同樣可以給靜態(tài)頁面锌俱,并使用javascript來獲得相信應(yīng)的參數(shù)值。

7敌呈、window.location.hash(設(shè)置或獲取 href 屬性中在井號“#”后面的分段)

var test = window.location.hash;

alert(test);

返回:空字符(因?yàn)閡rl中沒有)

8贸宏、js獲取url中的參數(shù)值

一、正則法

functiongetQueryString(name) {

??varreg = newRegExp('(^|&)'+ name + '=([^&]*)(&|$)', 'i');

??varr = window.location.search.substr(1).match(reg);

??if(r != null) {

????returnunescape(r[2]);

??}

??returnnull;

}

// 這樣調(diào)用:

alert(GetQueryString("參數(shù)名1"));


alert(GetQueryString("參數(shù)名2"));


alert(GetQueryString("參數(shù)名3"));

二磕洪、split拆分法

functionGetRequest() {

??varurl = location.search; //獲取url中"?"符后的字串

??vartheRequest = newObject();

??if(url.indexOf("?") != -1) {

????varstr = url.substr(1);

????strs = str.split("&");

????for(vari = 0; i < strs.length; i ++) {

??????theRequest[strs[i].split("=")[0]] = unescape(strs[i].split("=")[1]);

????}

??}

??returntheRequest;

}

varRequest = newObject();

Request = GetRequest();<br>// var id=Request["id"];

// var 參數(shù)1,參數(shù)2,參數(shù)3,參數(shù)N;

// 參數(shù)1 = Request['參數(shù)1'];

// 參數(shù)2 = Request['參數(shù)2'];

// 參數(shù)3 = Request['參數(shù)3'];

// 參數(shù)N = Request['參數(shù)N'];

三吭练、指定取

比如說一個url:http://i.cnblogs.com/?j=js,我們想得到參數(shù)j的值,可以通過以下函數(shù)調(diào)用褐鸥。

functionGetQueryString(name) {

??varreg = newRegExp("(^|&)"+ name + "=([^&]*)(&|$)", "i");

??varr = window.location.search.substr(1).match(reg); //獲取url中"?"符后的字符串并正則匹配

??varcontext = "";

??if(r != null)

?????context = r[2];

??reg = null;

??r = null;

??returncontext == null|| context == ""|| context == "undefined"? "": context;

}

alert(GetQueryString("j"));

四线脚、單個參數(shù)的獲取方法

functionGetRequest() {

??varurl = location.search; //獲取url中"?"符后的字串

??if(url.indexOf("?") != -1) {? //判斷是否有參數(shù)

???varstr = url.substr(1); //從第一個字符開始 因?yàn)榈?個是?號 獲取所有除問號的所有符串

???strs = str.split("=");? //用等號進(jìn)行分隔 (因?yàn)橹乐挥幸粋€參數(shù) 所以直接用等號進(jìn)分隔 如果有多個參數(shù) 要用&號分隔 再用等號進(jìn)行分隔)

???alert(strs[1]);???? //直接彈出第一個參數(shù) (如果有多個參數(shù) 還要進(jìn)行循環(huán)的)

??}

}

摘自:https://www.jb51.net/article/82519.htm

以上就是本文的全部內(nèi)容赐稽,希望對大家理解如何獲取當(dāng)前頁面url網(wǎng)址信息有所幫助叫榕。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末浑侥,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子晰绎,更是在濱河造成了極大的恐慌寓落,老刑警劉巖,帶你破解...
    沈念sama閱讀 222,590評論 6 517
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件荞下,死亡現(xiàn)場離奇詭異伶选,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 95,157評論 3 399
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來逢享,“玉大人鞭盟,你說我怎么就攤上這事〉停” “怎么了?”我有些...
    開封第一講書人閱讀 169,301評論 0 362
  • 文/不壞的土叔 我叫張陵,是天一觀的道長河绽。 經(jīng)常有香客問我,道長唉窃,這世上最難降的妖魔是什么耙饰? 我笑而不...
    開封第一講書人閱讀 60,078評論 1 300
  • 正文 為了忘掉前任,我火速辦了婚禮纹份,結(jié)果婚禮上苟跪,老公的妹妹穿的比我還像新娘。我一直安慰自己蔓涧,他們只是感情好削咆,可當(dāng)我...
    茶點(diǎn)故事閱讀 69,082評論 6 398
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著蠢笋,像睡著了一般拨齐。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上昨寞,一...
    開封第一講書人閱讀 52,682評論 1 312
  • 那天瞻惋,我揣著相機(jī)與錄音,去河邊找鬼援岩。 笑死歼狼,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的享怀。 我是一名探鬼主播羽峰,決...
    沈念sama閱讀 41,155評論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了梅屉?” 一聲冷哼從身側(cè)響起值纱,我...
    開封第一講書人閱讀 40,098評論 0 277
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎坯汤,沒想到半個月后虐唠,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,638評論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡惰聂,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,701評論 3 342
  • 正文 我和宋清朗相戀三年疆偿,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片搓幌。...
    茶點(diǎn)故事閱讀 40,852評論 1 353
  • 序言:一個原本活蹦亂跳的男人離奇死亡杆故,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出溉愁,到底是詐尸還是另有隱情反番,我是刑警寧澤,帶...
    沈念sama閱讀 36,520評論 5 351
  • 正文 年R本政府宣布叉钥,位于F島的核電站罢缸,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏投队。R本人自食惡果不足惜枫疆,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,181評論 3 335
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望敷鸦。 院中可真熱鬧息楔,春花似錦、人聲如沸扒披。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,674評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽碟案。三九已至愿险,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間价说,已是汗流浹背辆亏。 一陣腳步聲響...
    開封第一講書人閱讀 33,788評論 1 274
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留鳖目,地道東北人扮叨。 一個月前我還...
    沈念sama閱讀 49,279評論 3 379
  • 正文 我出身青樓,卻偏偏與公主長得像领迈,于是被迫代替她去往敵國和親彻磁。 傳聞我的和親對象是個殘疾皇子碍沐,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,851評論 2 361

推薦閱讀更多精彩內(nèi)容