用javascript替換URL中的引數值
今天遇到一個需要用javascript將url中的某些引數替換的需求,想起了不久前從先生的部落格中淘到了一個,正好可以藉此實現,程式碼整理如下:
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
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
|
//分析url function parseURL(url) {
var a = document.createElement( 'a' );
a.href = url;
return {
source: url,
protocol: a.protocol.replace( ':' , '' ),
host: a.hostname,
port: a.port,
query: a.search,
params: ( function () {
var ret = {},
seg = a.search.replace(/^?/, '' ).split( '&' ),
len = seg.length, i = 0, s;
for (; i
if (!seg[i]) { continue ; }
s = seg[i].split( '=' );
ret[s[0]] = s[1];
}
return ret;
})(),
file: (a.pathname.match(//([^/? #]+)$/i) || [, ''])[1],
hash: a.hash.replace( '#' , '' ),
path: a.pathname.replace(/^([^/])/, '/$1' ),
relative: (a.href.match(/tps?://[^/]+(.+)/) || [, '' ])[1],
segments: a.pathname.replace(/^ //, '').split('/')
};
} //替換myUrl中的同名引數值 function replaceUrlParams(myUrl, newParams) {
for ( var x in newParams) {
var hasInMyUrlParams = false ;
for ( var y in myUrl.params) {
if (x.toLowerCase() == y.toLowerCase()) {
myUrl.params[y] = newParams[x];
hasInMyUrlParams = true ;
break ;
}
}
//原來沒有的引數則追加
if (!hasInMyUrlParams) {
myUrl.params[x] = newParams[x];
}
}
var _result = myUrl.protocol + "://" + myUrl.host + ":" + myUrl.port + myUrl.path + "?" ;
for ( var p in myUrl.params) {
_result += (p + "=" + myUrl.params[p] + "&" );
}
if (_result.substr(_result.length - 1) == "&" ) {
_result = _result.substr(0, _result.length - 1);
}
if (myUrl.hash != "" ) {
_result += "#" + myUrl.hash;
}
return _result;
} //輔助輸出 function w(str) {
document.write(str + " );
} var myURL = parseURL( '' );
w( "myUrl.file = " + myURL.file) // = 'index.html'
w( "myUrl.hash = " + myURL.hash) // = 'top'
w( "myUrl.host = " + myURL.host) // = 'abc.com'
w( "myUrl.query = " + myURL.query) // = '?id=255&m=hello'
w( "myUrl.params = " + myURL.params) // = Object = { id: 255, m: hello }
w( "myUrl.path = " + myURL.path) // = '/dir/index.html'
w( "myUrl.segments = " + myURL.segments) // = Array = ['dir', 'index.html']
w( "myUrl.port = " + myURL.port) // = '8080'
w( "myUrl.protocol = " + myURL.protocol) // = 'http'
w( "myUrl.source = " + myURL.source) // = ''
var _newUrl = replaceUrlParams(myURL, { id: 101, m: "World" , page: 1, "page" :2 });
w( " )
w(_newUrl); //
|
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/855/viewspace-2808432/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- .NET正則替換URL引數值
- JavaScript獲取url傳遞的引數值JavaScript
- JavaScript 獲取 url 傳遞引數值JavaScript
- bash 引數替換中的模式匹配模式
- C#獲取URL引數值C#
- C# 解析獲取Url引數值C#
- Java替換RequstBody和RequestParam引數的屬性Java
- SAP Fiori 應用 url 中的 DraftUUID 引數的含義RaftUI
- Excel 多個變數替換 實際值Excel變數
- React中的url引數——this.props.matchReact
- javascript的簡單模板替換JavaScript
- 教你如何替換@PathVariable中的變數變數
- Asp.Net MVC路由引數獲取、替換ASP.NETMVC路由
- 數值型模板引數的應用
- JS實現JSON物件與URL引數的相互轉換JSON物件
- Django裡URL配置中name引數的作用Django
- 由引數URL想到的
- jQuery接收url的引數jQuery
- JavaScript 中的引數處理JavaScript
- JavaScript 字串轉換數值型別JavaScript字串型別
- 使用JMeter從JSON響應的URL引數中提取特定值JMeterJSON
- 介面自動化之引數動態生成替換
- JavaScript函式引數解構賦值JavaScript函式賦值
- 獲取url中?後面傳遞的引數
- 替換NULL值幫助文件Null
- Go 1.22中路由 URL 路由引數Go路由
- python json格式轉url引數&分割, url引數轉json格式PythonJSON
- JavaScript字串中URL的檢測並轉換為連結JavaScript字串
- 獲取url上的引數
- js解析url引數JS
- js中字串的替換JS字串
- 三種方法實現:獲取 url 中的引數
- vue-router如何實時地址不變,動態替換路由引數(位址列引數)Vue路由
- 函式中引數傳值函式
- JavaScript replace()替換字串中指定字元JavaScript字串字元
- JavaScript 替換字串全部指定內容JavaScript字串
- 動態路由(URL引數)路由
- Java替換PDF中的字型Java