使用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));
相关推荐
fruge1 小时前
Vue Pinia 状态管理实战指南
前端·vue.js·ubuntu
sean1 小时前
开发一个自己的 claude code
前端·后端·ai编程
用户21411832636022 小时前
dify案例分享-用 Dify 一键生成教学动画 HTML!AI 助力,3 分钟搞定专业级课件
前端
chxii2 小时前
ISO 8601日期时间标准及其在JavaScript、SQLite与MySQL中的应用解析
开发语言·javascript·数据库
没逛够2 小时前
Vue 自适应高度表格
javascript·vue.js·elementui
太过平凡的小蚂蚁3 小时前
Kotlin 协程中常见的异步返回与控制方式(速览)
开发语言·前端·kotlin
咖啡の猫4 小时前
Vue初始化脚手架
前端·javascript·vue.js
晨枫阳4 小时前
uniapp兼容问题处理总结
前端·vue.js·uni-app
liusheng6 小时前
腾讯地图 SDK 接入到 uniapp 的多端解决方案
前端·uni-app
拉不动的猪6 小时前
如何处理管理系统中(Vue PC + uni-app 移动端):业务逻辑复用基本方案
前端·javascript·架构