data:image/s3,"s3://crabby-images/5a17c/5a17cb8cdb3bf4fbe54b3bff68be30aa65fecf0b" alt=""
如果使用传统的 if-else 语句,对复杂的条件进行逻辑判断,代码很容易变得冗长难维护,分享几种替代的写法。
1. 对象映射替代 if-else传统写法
function getPrice(user) { if (user.type === 'vip') { return 'VIP价格'; } else if (user.type === 'svip') { return 'SVIP价格'; } else if (user.type === 'vvip') { return 'VVIP价格'; } else { return '普通价格'; }}替代写法
const priceStrategy = { vip: () => 'VIP价格', svip: () => 'SVIP价格', vvip: () => 'VVIP价格', default: () => '普通价格'};function getPrice(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. 三元运算符链式使用传统写法
data:image/s3,"s3://crabby-images/145d6/145d690a880abe5c3d3b0c79d18f8534ef061371" alt=""
替代写法
data:image/s3,"s3://crabby-images/6155c/6155c779cf52c8c0f2740256f4f3c88174ee8fad" alt=""
data:image/s3,"s3://crabby-images/ae26a/ae26a50d04993fbf52fb346c7d8b77b0512093e1" alt=""
data:image/s3,"s3://crabby-images/ae617/ae617b3e598e82e39a1029be18eec40ba4843138" alt=""
data:image/s3,"s3://crabby-images/85a5a/85a5a4beb078a6c8b331c1b94cbeafcc3c107498" alt=""
data:image/s3,"s3://crabby-images/24b17/24b176b958bfca77819ea3a6daa6b5016b3c5377" alt=""
data:image/s3,"s3://crabby-images/c0f94/c0f9492d8e839291175688703b374b116d8db662" alt=""