LOGO OA教程 ERP教程 模切知识交流 PMS教程 CRM教程 开发文档 其他文档  
 
网站管理员

不用 if else,如何优雅处理 JavaScript 条件判断?

admin
2025年10月16日 19:34 本文热度 209

如果使用传统的 if-else 语句,对复杂的条件进行逻辑判断,代码很容易变得冗长难维护,分享几种替代的写法。

1. 对象映射替代 if-else

传统写法

functiongetPrice(user) {
if (user.type === 'vip') {
return'VIP价格';
    } elseif (user.type === 'svip') {
return'SVIP价格';
    } elseif (user.type === 'vvip') {
return'VVIP价格';
    } else {
return'普通价格';
    }
}

替代写法

const priceStrategy = {
    vip: () => 'VIP价格',
    svip: () => 'SVIP价格',
    vvip: () => 'VVIP价格',
    default: () => '普通价格'
};

functiongetPrice(user) {
return (priceStrategy[user.type] || priceStrategy.default)();
}

2. Array.includes 替代多条件

传统写法

if (status === 'failed' || status === 'error' || status === 'rejected') {
handleError();
}

替代写法

const errorStatus = ['failed''error''rejected'];
if (errorStatus.includes(status)) {
handleError();
}

3. 三元运算符链式使用

传统写法

替代写法

4. && 和 || 运算符巧用

5. Switch 模式匹配

6. 使用 Proxy 进行条件拦截

7. 函数式编程方法

8. 状态机模式

9. 使用装饰器处理条件

functioncheckPermission(target, name, descriptor) {
const original = descriptor.value;
    descriptor.value = function(...args) {
if (this.user?.hasPermission) {
return original.apply(this, args);
        }
thrownewError('No permission');
    };
return descriptor;
}

classDocument {
    @checkPermission
edit() {
// 编辑文档
    }
}

欢迎补充。


阅读原文:原文链接


该文章在 2025/10/17 17:36:30 编辑过
关键字查询
相关文章
正在查询...
点晴ERP是一款针对中小制造业的专业生产管理软件系统,系统成熟度和易用性得到了国内大量中小企业的青睐。
点晴PMS码头管理系统主要针对港口码头集装箱与散货日常运作、调度、堆场、车队、财务费用、相关报表等业务管理,结合码头的业务特点,围绕调度、堆场作业而开发的。集技术的先进性、管理的有效性于一体,是物流码头及其他港口类企业的高效ERP管理信息系统。
点晴WMS仓储管理系统提供了货物产品管理,销售管理,采购管理,仓储管理,仓库管理,保质期管理,货位管理,库位管理,生产管理,WMS管理系统,标签打印,条形码,二维码管理,批号管理软件。
点晴免费OA是一款软件和通用服务都免费,不限功能、不限时间、不限用户的免费OA协同办公管理系统。
Copyright 2010-2025 ClickSun All Rights Reserved