解析url查询参数问题

function parseQuery(query){
            var args = {};
            var items = query.split("&");

            var item = null, name = null, value = null;
            for(var i=0; i < items.length; i++){
                    item = items[i].split("=");
                    name = item[0];
                     value = item[1];
                     args[name] = value;
                }
               return args;
        }
        console.log(parseQuery("name=tom&age=12&gender&"));

怎么修改上述代码才能正常返回:{name: "tom", age: "12", gender: ""}

阅读 5k
2 个回答
function parseQuery(query){
    var args = {};
    var items = query.split("&");

    var item = null, name = null, value = null;
    for(var i=0; i < items.length; i++){
        item = items[i].split("=");
        if(item[0]){
            name = item[0];
            value = item[1] ? item[1] : "";
            args[name] = value;
        }
    }
    return args;
}

类似url解析,面向数据处理,使用函数式编程(FP)最为优雅。应楼主需求,把这个功能包装成一个函数。

function parseQuery(str){
  return str.split('&').reduce((memo, x) => {
    let qa = x.split('=');
    if(!qa[0]) return memo;
    return Object.assign(memo, {
      [qa[0]]: qa[1]?qa[1]:""
    })
  }, {})
}

上面是ES6/7代码,具体转换和运行示例猛戳这里

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题