使用ES5和ES6求函数参数的和、解析URL Params为对象

文章目录

  • [1 使用ES5和ES6求函数参数的和](#1 使用ES5和ES6求函数参数的和)
    • [1.1 ES5](#1.1 ES5)
    • [1.2 ES6](#1.2 ES6)
  • [2 解析URL Params为对象](#2 解析URL Params为对象)

1 使用ES5和ES6求函数参数的和

1.1 ES5

javascript 复制代码
function sum() {
    let sum = 0;
    Array.prototype.forEach.call(arguments, function(item) {
        sum += item * 1;
    })
    return sum;
}

1.2 ES6

javascript 复制代码
function sum(...nums) {
    let sum = 0;
    nums.forEach(function(item) {
        sum += item * 1;
    })
    return sum;
}

2 解析URL Params为对象

javascript 复制代码
/**
 * 结果:
 * { 
 *   user: 'anonymous',
 *   id: [ 123, 456 ], // 重复出现的 key 要组装成数组,能被转成数字的就转成数字类型
 *   city: '北京',     // 中文需解码
 *   enabled: true,   // 未指定值得 key 约定为 true
 * }
 */
let url = 'http://www.domain.com/?user=anonymous&id=123&id=456&city=%E5%8C%97%E4%BA%AC&enabled';

function parseParam(url) {
    let paramStr = /.+\?(.+)$/.exec(url)[1];
    let paramArr = paramStr.split('&');
    let paramObj = {};
    paramArr.forEach(function(item) {
        if (/=/.test(item)) {
            let [key, value] = item.split('=');
            value = decodeURIComponent(value);
            value = /^\d+$/.test(value) ? parseFloat(value) : value;
            if (paramObj.hasOwnProperty(key)) {
                paramObj[key] = [].concat(paramObj[key], value);
            } else {
                paramObj[key] = value;
            }
        } else {
            paramObj[item] = true;
        }
    })
    return paramObj;
}
console.log(parseParam(url));
相关推荐
小和尚敲木头28 分钟前
krpano 字符串拼接,传参。
java·linux·前端
程序猿小D29 分钟前
第11节 Node.js 模块系统
服务器·前端·node.js·编辑器·vim
Data_Adventure1 小时前
SVG动画详解:animate与animateTransform
前端·svg
小疯仔1 小时前
使用el-input数字校验,输入汉字之后校验取消不掉
android·开发语言·javascript
wangbing11251 小时前
开发指南120-表格(el-table)斑马纹
javascript·vue.js·elementui
Joe5561 小时前
antDesignVue中a-upload上传组件的使用
前端·javascript
WKK_1 小时前
el-select 实现分页加载,切换也数滚回到顶部,自定义高度
前端·javascript·vue.js·elementui
保持学习ing1 小时前
帝可得 - 策略管理
java·javascript·vue.js·elementui·若依框架
一口一个橘子1 小时前
[ctfshow web入门] web78
前端·web安全·网络安全
咔咔库奇1 小时前
开发者体验提升:打造高效愉悦的开发环境
前端·javascript·vue.js·react.js·前端框架