使用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));
相关推荐
一 乐14 小时前
婚纱摄影网站|基于ssm + vue婚纱摄影网站系统(源码+数据库+文档)
前端·javascript·数据库·vue.js·spring boot·后端
C_心欲无痕15 小时前
ts - tsconfig.json配置讲解
linux·前端·ubuntu·typescript·json
清沫15 小时前
Claude Skills:Agent 能力扩展的新范式
前端·ai编程
yinuo16 小时前
前端跨页面通信终极指南:方案拆解、对比分析
前端
yinuo16 小时前
前端跨页面通讯终极指南⑨:IndexedDB 用法全解析
前端
xkxnq17 小时前
第二阶段:Vue 组件化开发(第 16天)
前端·javascript·vue.js
烛阴17 小时前
拒绝配置地狱!5 分钟搭建 Three.js + Parcel 完美开发环境
前端·webgl·three.js
Van_Moonlight17 小时前
RN for OpenHarmony 实战 TodoList 项目:空状态占位图
javascript·开源·harmonyos
xkxnq17 小时前
第一阶段:Vue 基础入门(第 15天)
前端·javascript·vue.js
anyup18 小时前
2026第一站:分享我在高德大赛现场学到的技术、产品与心得
前端·架构·harmonyos