用正則把url解析為對象


一、知識點
1. \ 將下一個字符標記為或特殊字符、或原義字符、或向后引用、或八進制轉義符。例如, 'n' 匹配字符 'n'。'\n' 匹配換行符。序列 '\\' 匹配 "\",而 '\(' 則匹配 "("。
2. ? 匹配前面的子表達式零次或一次,或指明一個非貪婪限定符。要匹配 ? 字符,請使用 \?。
3. | 替換,"或"操作字符具有高於替換運算符的優先級,使得"m|food"匹配"m"或"food"。若要匹配"mood"或"food",請使用括號創建子表達式,從而產生"(m|f)ood"。
4. g 執行全局匹配,而不是找到第一個匹配就停止.

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>string and reg</title>
</head>
<body>
<script>


var mylocation = {
'protocol':'',
'hostname':'',
'pathname':'',
'query':''
}
var url = 'http://adtk.cn/index.html?key1=1&key2=2';
var arr=url.split(/\:\/\/|\/|\?/g);
var j=0;
for(i in mylocation){
mylocation[i]=arr[j];
j++;
}
console.log(mylocation);

結果是:
Object {protocol: "http", hostname: "adtk.cn", pathname: "index.html", query: "key1=1&key2=2"}
hostname: "adtk.cn"
pathname: "index.html"
protocol: "http"
query: "key1=1&key2=2"
__proto__: Object

 

提醒:for in 會根據瀏覽器排序不同

1.經測試谷歌和IE對於數字會出錯

2.谷歌與IE會根據對象屬性首字母排序,可是對應的結果不會出錯,也就是說是先對應再排序的。附圖如下:

但是為了保險起見,還是避免用for in。

 

</script>
</body>
</html>


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM