js获取 url 参数

js获取 url 参数js 获取 url 参数获取 url 中的参数指定参数名称 返回该参数的值或者空字符串不指定参数名称 返回全部的参数对象或者 如果存在多个同名参数 则返回数组不支持 URLSearchPar 方法 functiongetU sUrl sKey letsParam sUrl split 1 split 0 key 1 amp key 2 amp key 3 amp test 4let

js获取 url 参数

获取 url 中的参数

  1. 指定参数名称,返回该参数的值 或者 空字符串
  2. 不指定参数名称,返回全部的参数对象 或者 {}
  3. 如果存在多个同名参数,则返回数组
  4. 不支持URLSearchParams方法
function getUrlParam(sUrl, sKey) { 
    let sParam = sUrl.split("?")[1].split("#")[0]; //key=1&key=2&key=3&test=4 let arr = sParam.split("&"); //["key=1","key=2","key=3","test=4"] let res; if( sKey ){ 
   //如果指定参数 res = []; for( let i = 0; i < arr.length; i++ ){ 
    var temp = arr[i].split("="); if( temp[0] === sKey ){ 
    res.push( temp[1] ); //res只存储指定key值的结果 } } if( res.length == 1 ){ 
    return res[0]; }else if( res.length == 0 ){ 
    return ""; }else{ 
    return res; } } else{ 
   //如果不指定参数 res = { 
   }; if( sParam==undefined || sParam=="" ){ 
    return res; } for( let i = 0; i < arr.length; i++ ){ 
    var temp = arr[i].split("="); if( !(temp[0] in res) ){ 
    res[temp[0]] = []; //temp[0]为键,temp[1]的数组为值 } res[temp[0]].push(temp[1]); //使用变量动态访问对象属性用obj[a]不能用obj.a } } return res; } 
var paramArr = sUrl.split('?')[1].split('#')[0].split('&'); // 取出每个参数的键值对放入数组 const obj = { 
   }; paramArr.forEach(element => { 
    const [key, value] = element.split('='); // 取出数组中每一项的键与值 if(obj[key] === void 0){ 
    // 表示第一次遍历这个元素,直接添加到对象上面 obj[key]=value } else{ 
    obj[key]=[].concat(obj[key],value); // 表示不是第一次遍历说明这个键已有,通过数组存起来。 }}); return sKey===void 0? obj:obj[sKey]||'' // 如果该方法为一个参数,则返回对象。 //如果为两个参数,sKey存在,则返回值或数组,否则返回空字符。 
function getUrlParam(sUrl, sKey) { 
    var r=/(\?|&)(\w+)\=(\w+)/g; var res={ 
   }; while(r.exec(sUrl)!=null){ 
    if(res[RegExp.$2]){ 
    var temp=res[RegExp.$2]; res[RegExp.$2]=[].concat(temp,RegExp.$3) }else{ 
    res[RegExp.$2]=RegExp.$3; } } if(sKey) { 
    return res[sKey]||''; } return res; } 
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/210752.html原文链接:https://javaforall.net

(0)
上一篇 2026年3月18日 下午11:58
下一篇 2026年3月18日 下午11:59


相关推荐

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号