php querystring,JS获取URL中参数值(QueryString)的4种方法分享_javascript技巧

方法一:正则法

function getQueryString(name) {

var reg = new RegExp('(^|&)' + name + '=([^&]*)(&|$)', 'i');

var r = window.location.search.substr(1).match(reg);

if (r != null) {

return unescape(r[2]);

}

return null;

}

// 这样调用:

alert(GetQueryString("参数名1"));

alert(GetQueryString("参数名2"));

alert(GetQueryString("参数名3"));

方法二:split拆分法

function GetRequest() {

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

var theRequest = new Object();

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

var str = url.substr(1);

strs = str.split("&");

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

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

}

}

return theRequest;

}

var Request = new Object();

Request = GetRequest();

// var 参数1,参数2,参数3,参数N;

// 参数1 = Request['参数1'];

// 参数2 = Request['参数2'];

// 参数3 = Request['参数3'];

// 参数N = Request['参数N'];

方法三:又见正则通过JS获取url参数,这个经常用到。比如说一个url:http://wwww.jb51.net/?q=js,我们想得到参数q的值,那可以通过以下函数调用即可。

function GetQueryString(name) {

var reg = new RegExp("(^|&)" + name + "=([^&]*)(&|$)", "i");

var r = window.location.search.substr(1).match(reg); //获取url中"?"符后的字符串并正则匹配

var context = "";

if (r != null)

context = r[2];

reg = null;

r = null;

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

}

alert(GetQueryString("q"));

方法四:单个参数的获取方法

function GetRequest() {

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

if (url.indexOf("?") != -1) { //判断是否有参数

var str = url.substr(1); //从第一个字符开始 因为第0个是?号 获取所有除问号的所有符串

strs = str.split("="); //用等号进行分隔 (因为知道只有一个参数 所以直接用等号进分隔 如果有多个参数 要用&号分隔 再用等号进行分隔)

alert(strs[1]); //直接弹出第一个参数 (如果有多个参数 还要进行循环的)

}

}

本文原创发布php中文网,转载请注明出处,感谢您的尊重!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
处理 URL Query 参数可以使用 JavaScript 内置的 `URLSearchParams` 对象或者第三方库 `querystring` 或 `lodash`。 以下是使用 `URLSearchParams` 对象的示例代码: ```javascript const params = new URLSearchParams(window.location.search); // 获取参数值 const foo = params.get('foo'); const bar = params.get('bar'); // 设置参数值 params.set('baz', '123'); // 删除参数 params.delete('foo'); // 将参数对象转换为字符串 const paramString = params.toString(); ``` 以下是使用 `querystring` 库的示例代码: ```javascript const querystring = require('querystring'); const params = querystring.parse(window.location.search.slice(1)); // 获取参数值 const foo = params.foo; const bar = params.bar; // 设置参数值 params.baz = 123; // 删除参数 delete params.foo; // 将参数对象转换为字符串 const paramString = querystring.stringify(params); ``` 以下是使用 `lodash` 库的示例代码: ```javascript const _ = require('lodash'); const params = _.chain(window.location.search.slice(1)) .split('&') .map(_.partial(_.split, _, '=', 2)) .fromPairs() .value(); // 获取参数值 const foo = params.foo; const bar = params.bar; // 设置参数值 params.baz = 123; // 删除参数 delete params.foo; // 将参数对象转换为字符串 const paramString = _.chain(params) .toPairs() .map(_.partial(_.join, _, '=', 2)) .join('&') .value(); ``` 以上三方法都可以实现 URL Query 参数的处理,具体使用哪一方法取决于个人喜好和项目需求。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值