目的

在项目中,if else语句如果用得很多,特别是嵌套,代码不美观,阅读性不好。所以的话,用其他的方式简化替换if...else...就很有必要。

简化的作用就是赠人玫瑰,手留余香。对自己对项目对别人都是好事。

if else语句是啥?好比下图。

如何简化

一、 借助短路运算符 && ||

这两个是啥?就是大学时代学习数电的与或。短路逻辑就是说是否执行第二个语句(操作数)取决与第一个操作数的结果。

我们可以用 && 来决定是否执行一段代码或者 || 设置默认值。

  1. // && || 经典模式
  2. if (foo) bar(); ==> foo&&bar();
  3. if (!foo) bar(); ==> foo||bar();
  4. //&& 别人博客例子
  5. function getInfoFromStorageBydid(key, did, success, error) {
  6. wx.getStorage({
  7. key: key,
  8. success: function (res) {
  9. var data = res.data[did];
  10. if (data) {
  11. typeof success === 'function' && success(data);
  12. wx.hideToast();
  13. } else {
  14. typeof error === 'function' && error();
  15. }
  16. },
  17. fail: function () {
  18. typeof error === 'function' && error();
  19. }
  20. });
  21. }
  22. //||
  23. if(a){a = a} else {a = b} ==> a = a || b;

二、使用三元表达式

平时开发中使用率很高,特别是在页面数组渲染是根据一个字段的值来判断给哪个单位,或者中文描述等等。只要是2选一的,就无脑用呗。

  1. if (foo) bar(); else baz(); ==> foo?bar():baz();
  2. if (!foo) bar(); else baz(); ==> foo?baz():bar();
  3. if(a == b ){ a = c }else { a = d } ==> a = (a==b)?c:d;

注意,三元表达式(操作符)不能使用return语句。

三、switch/case

如果if else的数量很大,分支很多,而且不仅仅是需要返回字段,需要干点什么。就用switch case吧。

例如

  1. xxx.done(function(data){
  2. switch(data.status){
  3. case 'success':
  4. //TODO
  5. break;
  6. case 'fail':
  7. //TODO
  8. break;
  9. default:
  10. //TODO
  11. }
  12. });

四、hase表(推荐)

hash表是什么?键值对的集合。对象就是hash

这个东西就类似映射那样。如果if else的数量很大,分支很多,而且就是让你返回一个字段。

就是上个月啊,和一个后台搞图片的功能。图片的待上传列表是那后台返回来的数组。写的时候,需要搞隐射,发现不好搞:一个页面,拿到SPECIAL_FATE_STORE_HEADER字段给后台specialFateStoreHeaderId字段;另外一个地方同理:specialFateStoreHeaderId->STORE_HEADER。为什么这么麻烦?后台小子逻辑差,经验不足,没处理好。一开始我使用switch case。搞了不少行代码,维护性也不好,因为有两套,改其中一个,另外一个也得跟着改。这时候,上面的那些数组遍历和对象遍历的内容就可以用进来了。再一次证明会js真的可以为所欲为,呵呵。代码如下。

  1. let valueMap = {
  2. SPECIAL_FATE_STORE_HEADER: 'specialFateStoreHeaderId'//值1:值2
  3. //...这里省略了15行
  4. }
  5. //获取值的值
  6. function getValueName(type) {
  7. return valueMap[type] ? valueMap[type] : valueMap['SPECIAL_FATE_STORE_HEADER'];
  8. }
  9. //获取键的值
  10. function getKeyName(targetValue){
  11. let targetArr = Object.keys(valueMap).filter((key) => { return valueMap[key] == targetValue });
  12. return targetArr.length === 0 ? 'STORE_HEADER' : targetArr[0].split('FATE_')[1]
  13. }
  14. console.log(getValueName('SPECIAL_FATE_STORE_HEADER'),'valueMap')
  15. console.log(getKeyName('specialFateStoreHeaderId'),'valueMap')

以后再次来需求,我就在valueMap对象里面加。万一再来需求,后台小子还要值3,值4怎么办?难不到我。我修改valueMap的结构。再改下逻辑就行。

  1. let valueMap = {
  2. SPECIAL_FATE_STORE_HEADER: 'specialFateStoreHeaderId&&值3&&值4'//值1:值2 && 值3 && 值4
  3. //...这里省略了15行
  4. }

就拿我在项目中的遇到的一个问题吧,有个搜索框,是很多页面共用的,可以查询客户经理,银行,分行等等。不同接口的方法类型和需要的数值不一样,情况就7到8种。我那个同事啊,写了很多if-else。看起来很麻烦,瞬间就不想再看。其实这时候可以使用hash来,结合反引号可以动态引入变量值。代码如下,注意啊,每个键值对都要加双引号(除非是数字),不能是单引号,否则JSON.parse会出现报错。

  1. let mapObj = {
  2. 1:`{
  3. "data": {"name": "${value}","branchId": ${this.id}},
  4. "type": "get"
  5. }`,
  6. 2:`{
  7. "data": {"name": "${value}"},
  8. "type": "post"
  9. }`
  10. }
  11. data = JSON.parse(mapObj[this.type]).data

五、省略括号

如果能省略括号就直接省略括号吧,阅读起来特别直观。

  1. //省略前
  2. if(a > b){
  3. console.log('a大');
  4. }else{
  5. console.log('b大');
  6. };
  7. //省略后
  8. if(a > b) console.log('a大');
  9. else console.log('b大');

最后,欢迎关注我的公众号。

js使用经验--if...else简化的更多相关文章

  1. node.js使用经验记录

    MongoDB使用经验: 有时不知道MongoDB的错误码代表什么,那有这个链接: https://github.com/mongodb/mongo/blob/master/src/mongo/bas ...

  2. HTML5 Canvas JavaScript库 Fabric.js 使用经验

    首先,表明我的态度:采用 Flash 才是最优方案,不建议使用 HTML 5 的 Canvas 做一些生产/工业级的网页应用. Flash的优势一是浏览器支持好,二是代码成熟稳定.而HTML5 的 C ...

  3. js使用经验--遍历

    目的 在平常的前端开发中,一般需要处理数据(数组和对象居多),特别是复杂功能的页面,通常是一到两个对象数组(有时数组里面还有数组).大多数前端开发的难点就是这里,耗时大.以前我在工作中,遇到的支付方式 ...

  4. JS当中利用&&和||简化代码

    ; ){ add_level = ; } ){ add_level = ; } ){ add_level = ; } ){ add_level = ; } else { add_level = ; } ...

  5. 【原】js 签到用日历

    最近做的一个项目中,需要用到一个日历来记录你的签到,网上找了一些,感觉挺庞大的,所以就自己写了一个,记录一下自己写这个日历的经过 html代码: <table cellspacing=" ...

  6. js 介绍

    createjs 工作内容:html5游戏开发岗位要求:1. 熟悉HTML5特性, 掌握canvas开发技能;2.能独立的搭建出易扩展,高效,强壮,通用的前端底层框架;3.熟悉常用的JS开发框架或工具 ...

  7. JQuery的$和其它JS发生冲突的快速解决方法

    众所周知,jQuery是目前最流行的JS封装包,简化了很多复杂的JS程序,JQuery讲浏览器DOM树定义为$,通过$来获取各个子节点. 然后,JS插件并非只有JQuery,还有prototype.j ...

  8. 前端JS插件整理

    1.JQuery.js JavaScript 库,简化JS. 官网地址:https://jquery.com/ 菜鸟教程:http://www.runoob.com/jquery/jquery-tut ...

  9. Angular、React.js 和Node.js到底选谁?

    为了工作,程序员选择正确的框架和库来构建应用程序是至关重要的,这也就是为什么Angular和React之间有着太多的争议.Node.js的出现,让这场战争变得更加复杂,虽然有选择权通常是一件很棒的事情 ...

随机推荐

  1. DataTable 与XML 交互

    一.将DataTable的内容写入到XML文件中 /// <summary> /// 将DataTable的内容写入到XML文件中 /// </summary> /// < ...

  2. centos下python多版本管理(pyenv+python+virtualenv+ipython)

    pyenv是个多版本python管理器,可以同时管理多个python版本共存,如pypy,miniconde等等 1 环境准备 安装相关软件和pyenv1.1 安装相关软件yum install -y ...

  3. Web前端开发必不可少的9个开源框架

    大多数人想到Web开发时,通常会想到HTML或JavaScript,往往忽略了CSS,根据Wikipedia的说法,CSS既是网页中最重要也是最常被遗忘的部分之一,尽管它是万维网的三大基础技术之一. ...

  4. thinkphp 5 一些常见问题

    ##  请求缓存 request_cache        

  5. Oracle把表记录恢复到指定时间节点

    可以执行以下命令alter table 表名 enable row movement; --开启表行移动flashback table 表名 to timestamp to_timestamp('20 ...

  6. MySQL简介和安装

    一.关系型数据库初识 1.1 什么是数据库? 数据库(Database)是按照数据结构来组织.存储和管理数据的仓库,每个数据库都有一个或多个不同的API用于创建,访问,管理,搜索和复制所保存的数据.我 ...

  7. 使用Xamarin开发即时通信系统 -- 基础篇(大量图文讲解 step by step,附源码下载)...

    如果是.NET开发人员,想学习手机应用开发(Android和iOS),Xamarin 无疑是最好的选择,编写一次,即可发布到Android和iOS平台,真是利器中的利器啊!而且,Xamarin已经被微 ...

  8. chrome清除缓存、不使用缓存而刷新快捷键

    Ctrl+Shift+Del  清除Google浏览器缓存的快捷键 Ctrl+Shift+R  重新加载当前网页而不使用缓存内容 转载于:https://www.cnblogs.com/JAVA-ST ...

  9. How to get binary string from ArrayBuffer?

    https://stackoverflow.com/questions/16363419/how-to-get-binary-string-from-arraybuffer https://stack ...

  10. 数学--数论--Miller_Rabin判断一个大数是不是素数(随机算法)

    前提知识 1,费马定理:ap−1=1(mod p)a^{p-1}=1(mod\ p)ap−1=1(mod p)