js实现QueryString功能

稿件来源: 阳光企业网站管理系统   撰稿作者: 太阳光   发表日期: 2013-11-12   阅读次数: 704   查看权限: 游客查看

服务器后台脚本都有获取链接地址参数功能,javascript也可以。

实际应用或者面试中都可能会要求你用js写一个方法实现获取链接地址的参数值,假如url:sdf.html?a=34&sd=sdfs&ds=8234&sd=&dfs=sdfsdf&a=jj

首先你应该直观知道可以从?号截断,再以&分割成数组,然后再以=分割成key与value即可:

var str="sdf.html?a=34&sd=sdfs&ds=8234&dfs=sdfsdf&a=jjj";
var t = str.split("?")[1];
var a = t.split("&");
var o = {};
    for(var i=0;i< a.length;i++){
        var l = a[i].split("=");
        o[l[0]]=l[1];
    }
console.log(o);

这是最原始最初级的方法,存在一些问题:没有考虑含有#,也没考虑重复的变量。曾经在CSDN有人改为:

function GetQueryString(name) {
    var reg = new RegExp("[&\?]" + name + "=([^&#]*)", "ig");
    var res = [];
    location.search.replace(reg, function ($, $1) {
        res.push($1);
    });
    return res;
}

此方法精明多了,使用正侧。并考虑了#及重复变量问题。但仍有不理想的地方:一是每次获取都需要匹配,二是返回结果为数组。我希望的是像asp一样,有重复变量时,返回的多个值之间以,号隔开,但仍是字符串。最好不要反复匹配:

    var obj={};
    location.search.replace(/[\?&]([^=#]+)=([^&#]*)/g,function($1,$2,$3){
        obj[$2] = obj[$2] ? obj[$2]+","+$3 : $3;
    });
    console.log(obj);

 

 

 

关键词: js,querystring,获取参数   编辑时间: 2013-11-12 16:38:01

  • 感到高兴

    0

    高兴
  • 感到支持

    0

    支持
  • 感到搞笑

    0

    搞笑
  • 感到不解

    0

    不解
  • 感到谎言

    0

    谎言
  • 感到枪稿

    0

    枪稿
  • 感到震惊

    0

    震惊
  • 感到无奈

    0

    无奈
  • 感到无聊

    0

    无聊
  • 感到反对

    0

    反对
  • 感到愤怒

    0

    愤怒
50%(2)
50%(2)
共有0 条评论 发言请遵守【相关规定

网友评论

会员头像
发 表同步腾讯微博    验证码:  点击更新请先登陆
  • 暂无评论
关闭模块文章图片 article Pictrue
  • 我的妈妈爸爸
  • 基于koa2+mysql+vue2.0+Element阳光内容管理系统
  • 代码覆盖率工具 Istanbul 入门教程
  • 全栈工程师的武器——MEAN
  • 9款超炫的 CSS3 复选框(Checkbox)
  • 微信开发在线翻译功能
  • CSS3那些不为人知的高级属性
  • 给easyui的datebox添加清空事件
  • flash写字效果
  • kendoUI系列教程之DropDownList下拉菜单
  • kendoUI系列教程之datetimepicker日期时间选择
  • kendoUI系列教程之datepicker日期选择
  • kendoUI系列教程之combobox下拉列表框
  • kendoUI系列教程之colorpicker
  • kendoUI系列教程之calendar日历表
  • kendoUI系列教程之autocomplete自动补齐