if语句的几种优化

js中if语句的几种优化代码写法

Java学习交流群:471651004

尽管我还没使用它去做一些尝试性的测试,但从这里可以看到它的确对js作了美化的工作。也许有人认为if语句就那么简单,能优化到什么程度?但是看看以下的几种方式,你也许会改变看法。

一、使用常见的三元操作符

  复制代码 代码如下:

if (foo) bar(); else baz(); ==> foo?bar():baz();

if (!foo) bar(); else baz(); ==> foo?baz():bar();

if (foo) return bar(); else return baz(); ==> return foo?bar():baz();

 

对于以上使用三元操作符来优化if语句你肯定不会陌生,或许你经常使用它。

 

二、使用and(&&)和or(||)运算符

  复制代码 代码如下:

if (foo) bar(); ==> foo&&bar();

if (!foo) bar(); ==> foo||bar();

 

老实说,我并没有这样去写过代码,这种写法我在学习《鸟哥的 Linux 私房菜》时看到过,但我并没想到在js中实现它。

 

三、省略大括号{}

  复制代码 代码如下:

if (foo) return bar(); else something(); ==> {if(foo)return bar();something()}

这种写法你我都很熟悉,但我建议在代码优化的时候这样做,或者交给UglifyJS帮你去解决。毕竟少一个大括号,代码的可阅读性并不高。

写到这里,我想到jQuery之父在《精通 JavaScript》中的一个获取HTML元素属性的方法。

  复制代码 代码如下:

function getAttr(el, attrName){

var attr = {'for':'htmlFor', 'class':'className'}[attrName] || attrName;

};

如果我们不这样写,可能我们需借助于两个if语句来进行处理,而上面的代码不仅简洁有效,而且可阅读性强。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
if else语句的代码优化可以通过以下几种方式实现。首先,可以使用三元操作符来代替简单的if-else语句,从而使代码更简洁。例如,将if (foo) bar(); else baz(); 优化为 foo?bar():baz();。其次,可以使用switch语句来替代多个if-else语句,特别是在需要对多个条件进行判断时。这样可以减少代码的嵌套和冗余。另外,可以通过使用多个if语句的嵌套来进行条件判断,但是需要注意减少嵌套层次,以提高代码的可读性和维护性。最后,可以考虑使用设计模式中的策略模式或者状态模式来替代复杂的if-else逻辑,使代码更加灵活和可扩展。总之,通过使用合适的代码结构和设计模式,可以优化if-else语句的代码,提高代码的可读性和可维护性。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [改善丑陋的代码——多重if-else语句优化(卫语句)](https://blog.csdn.net/qq_39485686/article/details/122145405)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* [js中if语句几种优化代码写法](https://download.csdn.net/download/weixin_38531630/13667398)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值