js使用正则获取当前页面url指定参数

JavaScript023

js使用正则获取当前页面url指定参数,第1张

网址: http://1.com/

调用: QueryString('name')

返回: null

网址: http://1.com/?name=cwj&age=21

调用: QueryString('name')

返回: cwj

现在随便拿一个网址: https://m.weibo.cn/u/5902368392?topnav=1&wvr=6&is_all=1&jumpfrom=weibocom ,这个网址的 location 是:

所以这个地址的 location.search 是 ?topnav=1&wvr=6&is_all=1&jumpfrom=weibocom ,这就是需要执行匹配的字符串

match() 方法可在字符串内检索指定的值,或找到一个或多个正则表达式的匹配。

存放匹配结果的数组。在这个方法中将匹配结果放在了数组 sValue 中。

RegExp 对象表示正则表达式

该对象接受两个参数,第一个参数是一个字符串,指定了正则表达式的模式或其他正则表达式。第二个参数 i 代表着区分大小写的匹配。

调用该方法: QueryString('wvr') ,根据以上正则表达式匹配出来的结果是:

要注意的是 match 方法返回的数组 0 位置是匹配的字符串,所以相应参数在 sValue[1] 中

var url = 'http://xxx.com/index.php?page=1'

url = url.replace(/(http:\/\/xxx\.com\/index\.php\?page=)(\d+)/,function(){

    return arguments[1]+'2'

})

不建议使用正则,可使用location对象提取page参数进行处理

代码如下:

<!DOCTYPE html>

<html>

<head>

<meta charset="utf-8">

<title>index</title>

</head>

<body>

<script>

var str = "http://www.nowcoder.com?key=1&key=2&key=3&test=4#hehe"

var patt1 = /key=\d/ig//匹配key=开头,后面匹配一个数字 i表示忽略大小写 g表示尽可能多的匹配

document.write("用正则表达式取值为:" + str.match(patt1))

document.write("<br />")

var arr = str.match(patt1)

var result = []

console.log(str.match(patt1)) // [key=1,key=2,key=3]

for (var i = 0i <arr.lengthi++) {

result.push(parseInt(arr[i].substr(4, 1)))

}

document.write("最终的结果为:[" + result + "]")

</script>

</body>

</html>