我在教新手编程时,喜欢给他们一些小小的挑战,比如:不使用if语句(或者三元运算符、switch语句等)解决一些编程问题。这样做有什么意义吗?事实上,它可以迫使你从不同的角度寻找解决方法,也许可以找到更好的方法。

正文共:2799 字

预计阅读时间:7 分钟

我在教新手编程时,喜欢给他们一些小小的挑战,比如:不使用if语句(或者三元运算符、switch语句等)解决一些编程问题。

这样做有什么意义吗?

事实上,它可以迫使你从不同的角度寻找解决方法,也许可以找到更好的方法。

当然,使用if语句没有任何不对的地方。但是,不使用if的话,有时候可以增加代码的可读性。这一点并不是绝对的,如果完全不使用if语句的话,代码可读性也许会更差。这需要你根据不同情况去判断。

而且,不用if的话不只是影响可读性。在这背后隐含着更加深刻的道理。通过了解本文的代码示例,你可以发现,如果不使用if语句的话,你的代码会更加接近代码即数据的概念。

另外,当你尝试不使用if语句去编程时,也是一件非常有意思的事情。

示例1: 统计数组中的奇数

假设我们有一个整数数组arrayOfIntegers,现在需要统计其中奇数的个数:


const arrayOfIntegers = [1, 4, 5, 9, 0, -1, 5];

使用if


let counter = 0; 
arrayOfIntegers.forEach((integer) => { 
 const remainder = Math.abs(integer % 2); 
 if (remainder === 1) { 
   counter++; 
 } 
});

console.log(counter); 
console.log(counter);

不用if


let counter = 0;

arrayOfIntegers.forEach((integer) => { 
 const remainder = Math.abs(www.huarenyl.cn   integer % 2); 
 counter += remainder; 
});

console.log(counter);

不用if时,我们巧妙地利用了奇数与偶数的特性,它们除以2的余数分别是0和1。

示例2: 判断工作日和周末

给定一个日期(比如new Date()),判断它是工作日还是周末,分别返回”weekend”和”weekday”。

使用if


const weekendOrWeekday = (inputDate) => { 
 const day = inputDate.getDay();

if (day === 0 || day === 6) { 
   return 'weekend'; 
 }  
  
 return 'weekday';

// Or, for ternary fans: 
 // return (day === 0 || day www.006665.cn   === 6) ? 'weekend' : 'weekday'; 
};

console.log(weekendOrWeekday(new Date()));

不用if


const weekendOrWeekday = www.006665.cn  (inputDate) => { 
 const day = inputDate.getDay();

return weekendOrWeekday.labels[day] ||  
        weekendOrWeekday.www.wanmeiyuele.cn  labels['default']; 
};

weekendOrWeekday.labels = {  
 0: 'weekend',  
 6: 'weekend',  
 default: 'weekday'  
};

console.log(weekendOrWeekday(new Date()));

你是否发现if语句中其实隐含着一些信息呢?它告诉我们哪一天是周末,哪一天是工作日。因此,要去掉if语句的话,我们只需要把这些信息写入weekendOrWeekday.labels对象,然后直接使用它就好了。

示例3: doubler函数

写一个doubler函数,它会根据参数的类型,进行不同的操作:

  1. 如果参数是数字,则乘以2(i.e. 5 => 10, -10 => -20);

  2. 如果参数是字符串,则每个字符重复2次 (i.e. 'hello' => 'hheelloo');

  3. 如果参数是函数,则调用2次;

  4. 如果参数是数组,则将每一个元素作为参数,调用doubler函数

  5. 如果参数是对象,则将每个属性值作为参数,调用doubler函数

使用switch


const doubler = (input) => { 
 switch (typeof input) { 
   case 'number': 
     return input + input; 
   case 'string': 
     return input 
       .split('') 
       .map((letter) => letter + letter) 
       .join(''); 
   case 'object': 
     Object.keys(input) 
           .map((key) =www.365soke.cn > (input[key] = doubler(input[key]))); 
     return input; 
   case 'function': 
     input(); 
     input(); 
 } 
};

console.log(doubler(-10)); 
console.log(doubler('hey')); 
console.log(doubler([5, 'hello'])); 
console.log(doubler({ a: 5,www.huayi1.cn  b: 'hello' })); 
console.log( 
 doubler(function() { 
   console.log('call-me'); 
 }), 
);

不用switch


const doubler = (input) => { 
 return doubler.operationsByType[typeof input](input); 
};

doubler.operationsByType = { 
 number: (input) => input + input, 
 string: (input) => 
   input 
     .split('') 
     .map((letter) => letter + www.255055.cn/ letter) 
     .join(''), 
 function: (input) => { 
   input(); 
   input(); 
 }, 
 object: (input) => { 
   Object.keys(input) 
         .map((key) => www.thd178.com (input[key] = doubler(input[key]))); 
   return input; 
 }, 
};

可知,我将每一种参数类型对应的操作绑定到了doubler.operationsByType,这样不需要switch语句,就可以实现doubler函数了。

注:为了保证可读性,本文采用意译而非直译。另外,本文版权归原作者所有,翻译仅用于学习。

译者:fundebug

出处:fundebug

链接:https:// www.taohuayuan178.com blog.fundebug.com/2017/11/06/write-javascript-without-if/

推荐阅读:

  • 我是如何在5个月内找到一份薪水翻番的工作的?

  • 刚开始学编程?这几款小工具能让你事半功倍

  • 我们整理了20个Python项目,送给正在求职的你

  • TIOBE 3月编程排行榜:Python突破第四,R跌至20

你试过不用if写代码吗?的更多相关文章

  1. 你试过不用if撸代码吗?

    译者按: 试着不用if撸代码,是件很有趣的事,而且,万一你领会了什么是“数据即代码,代码即数据”呢? 原文: Coding Tip: Try to Code Without If-statements ...

  2. [翻译] Canvas 不用写代码的动画

    Canvas 不用写代码的动画 https://github.com/CanvasPod/Canvas Canvas is a project to simplify iOS development ...

  3. [No000018B]写代码要用 Vim,因为越难入门的工具回报越大

    编者按:现在的技术界有一种倾向,将软件/应用操作简单化,用户能轻松上手.但是工具是否强大,取决于它能否灵活地满足使用者的各种需要.有些工具虽然很难入门,学会了便能对自己的操作有更深的层次的了解,能赋予 ...

  4. OO第三单元总结--根据JML写代码

    一. JML语言 1. 理论基础 首先,JML不是JAVA的一部分,它是一群研究者为JAVA设计的扩展部分,但还没有得到官方的支持.因此,JAVA编译器并不支持JML,所以要想JML起作用,只能采用类 ...

  5. 使用 .NET WinForm 开发所见即所得的 IDE 开发环境,实现不写代码直接生成应用程序

    直接切入正题,这是我09年到11年左右业余时间编写的项目,最初的想法很简单,做一个能拖拖拽拽就直接生成应用程序的工具,不用写代码,把能想到的业务操作全部封装起来,通过配置的方式把这些业务操作组织起来运 ...

  6. ClownFish:比手写代码还快的通用数据访问层

    http://www.cnblogs.com/fish-li/archive/2012/07/17/ClownFish.html 阅读目录 开始 ClownFish是什么? 比手写代码还快的执行速度 ...

  7. Markdown: 用写代码的思维写文档

    作者:吴香伟 发表于 2014/08/07 版权声明:可以任意转载,转载时务必以超链接形式标明文章原始出处和作者信息以及版权声明 本文不讲解Markdown的语法规则,只关注它带来的好处以及我使用的方 ...

  8. 【腾讯Bugly干货分享】深入理解 ButterKnife,让你的程序学会写代码

    本文来自于腾讯bugly开发者社区,非经作者同意,请勿转载,原文地址:http://dev.qq.com/topic/578753c0c9da73584b025875 0.引子 话说我们做程序员的,都 ...

  9. jQuery 之父:每天写代码

    去年秋天我的支线代码项目 遇到了一些问题,项目进展不足,而且我没法找到一个完成更多代码的方法(在不影响我在Khan Academy方面的工作的前提下). 我主要在周末进行我的支线,当然有时候也在晚上进 ...

随机推荐

  1. 神级编辑器 sublime text 和 神级插件 emmet

    h1{foo}和a[href=#] 生成如下代码 <h1>foo</h1>  <a href="#"></a> 嵌套的使用 > ...

  2. eclipse 右键没有Build Path

    如果Project Explorer右键没有build pathWindow ->show view 选择package explorer 参考https://blog.csdn.net/cod ...

  3. PHP代码统计文件大小(自动确定单位)

    php中有一个系统自带的计算文件大小的函数,就是filesize(),但是这个函数是以字节为单位的,但是在一些情况下,我们需要很直观的了解一个文件大小,就不仅仅需要字节B这个单位了,还需要KB,MB, ...

  4. nodejs环境变量配置

    步骤 创建文件夹:安装包 配置环境变量: export NODE_HOME=/root/安装包/node-v7.6.0-linux-x64 export PATH=$NODE_HOME/bin:$PA ...

  5. (数据科学学习手札21)sklearn.datasets常用功能详解

    作为Python中经典的机器学习模块,sklearn围绕着机器学习提供了很多可直接调用的机器学习算法以及很多经典的数据集,本文就对sklearn中专门用来得到已有或自定义数据集的datasets模块进 ...

  6. WPF中的命令与命令绑定(二)

    原文:WPF中的命令与命令绑定(二) WPF中的命令与命令绑定(二)                                              周银辉在WPF中,命令(Commandi ...

  7. [Jmeter]jmeter数据库性能测试配置

    学习jmeter过程中,记录一些学习过程中的点点滴滴,用于备忘.本文主要介绍的是如何创建一个简单的测试计划用户测试数据库服务器. 一.添加线程组 二.添加JDBC请求 1.在第一步里面定义并发用户以及 ...

  8. CC3200作为STA模式连接路由器sl_WlanConnect出现exception occured at:0xa72fcf6

    1. 先看下出错的提示 2. 出错的代码部分,现在问题是定位不到哪一行代码出问题,反正运行一段时间就进入了 lRetVal = sl_WlanConnect((signed , &secPar ...

  9. Kotlin 0

    #0 下载与配置: 官网上写的很详细,不再重复. #1 Hello world fun main(args: Array<String>) { println("Hello, w ...

  10. Qt 绘制汽车仪表 指针旋转锯齿问题

    在前面几篇中出现的问题 http://blog.csdn.net/z609932088/article/details/53946245 这个是在QWidget下绘制的,出现了指针有锯齿的问题 后面开 ...