JavaScript不刷新查找当前网址上的querystring并修改查询字符串变量

栏目: JavaScript · 发布时间: 6年前

内容简介:需要获取 param1/ param2 的变量,有时侯需要修改某个变量,有非常多的JS库可以实现,其实用简单的几行代码即可实现:var qs = {}qs.get = function(name) {

经常有些场景需要从网址获取变量,比如:

http://ourjs.com?param1=test1&param2=test2

需要获取 param1/ param2 的变量,有时侯需要修改某个变量,有非常多的JS库可以实现,其实用简单的几行代码即可实现:

var qs = {}

qs.get = function(name) {

var reg = new RegExp("[?&#]" + name + "=[^$&]*");

var parameter = location.href.match(reg)

if (!parameter) {

return;

return decodeURIComponent(parameter[0].substr(name.length + 2));

}

qs.set = function(name, value) {

var reg = new RegExp("([?&#]" + name + "=)[^$&]*")

var url = location.href

var parameter = url.match(reg)

if (parameter) {

url = url.replace(reg, '$1' + value)

} else {

var first = url.indexOf('#') > 0 ? '' : '#'

url += (url.indexOf('=') > 0 ? '&' : first) + name + '=' + value

}

history.replaceState && history.replaceState(null, null, url)

}

$.qs = qs;

使用:

qs.get('param1')
> test1

qs.set('param1', 'newvalue')
# 当前网址更新为:  http://ourjs.com?param1=newvalue&param2=test2

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

数字乌托邦

数字乌托邦

尼古拉斯•卡尔 / 姜忠伟 / 中信前沿出版社 / 2018-5 / 69.00

当下,技术与我们的关系变得越来越紧密不可分割,特别是智能手机等设备的出现,带给整个人类社会一场彻底的变革。的确,智能手机上的各种应用程序让我们的工作生活无比便利:社交媒体让我们能够和他人实时保持联络并传输信息,不再受时间、地点的限制;搜索引擎通过精准的算法将我们所需要的信息整合推送至屏幕上,让我们毫不费力就看到自己想要的;地图软件为我们的出行提供了更多路线选择,甚至可以使用语音导航,帮助我们顺利到......一起来看看 《数字乌托邦》 这本书的介绍吧!

URL 编码/解码
URL 编码/解码

URL 编码/解码

SHA 加密
SHA 加密

SHA 加密工具

HEX HSV 转换工具
HEX HSV 转换工具

HEX HSV 互换工具