广告
返回顶部
首页 > 资讯 > 前端开发 > html >JavaScript中不用if写代码有哪些特点
  • 421
分享到

JavaScript中不用if写代码有哪些特点

2024-04-02 19:04:59 421人浏览 独家记忆
摘要

这篇文章主要讲解了“不用if写代码有哪些特点”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“不用if写代码有哪些特点”吧!示例1: 统计数组中的奇数假设我们有

这篇文章主要讲解了“不用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(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 === 6) ? 'weekend' : 'weekday'; };  console.log(weekendOrWeekday(new Date()));

不用if

const weekendOrWeekday = (inputDate) => {   const day = inputDate.getDay();    return weekendOrWeekday.labels[day] ||           weekendOrWeekday.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) => (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, 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 + letter)       .join(''),   function: (input) => {     input();     input();   },   object: (input) => {     Object.keys(input)           .map((key) => (input[key] = doubler(input[key])));     return input;   }, };

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

感谢各位的阅读,以上就是“不用if写代码有哪些特点”的内容了,经过本文的学习后,相信大家对不用if写代码有哪些特点这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是编程网,小编将为大家推送更多相关知识点的文章,欢迎关注!

--结束END--

本文标题: JavaScript中不用if写代码有哪些特点

本文链接: https://www.lsjlt.com/news/85939.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • JavaScript中不用if写代码有哪些特点
    这篇文章主要讲解了“不用if写代码有哪些特点”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“不用if写代码有哪些特点”吧!示例1: 统计数组中的奇数假设我们有...
    99+
    2022-10-19
  • JavaScript代码组织结构良好的特点有哪些
    本篇内容主要讲解“JavaScript代码组织结构良好的特点有哪些”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“JavaScript代码组织结构良好的特点有哪些...
    99+
    2022-10-19
  • JavaScript中最常用的代码简写技巧有哪些
    这篇文章给大家分享的是有关JavaScript中最常用的代码简写技巧有哪些的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。一、三元操作符当想写if…else语句时,使用三元操作符来...
    99+
    2022-10-19
  • 编写JavaScript代码的小技巧有哪些
    小编给大家分享一下编写JavaScript代码的小技巧有哪些,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!1 Array.inc...
    99+
    2022-10-19
  • 编写现代JavaScript代码的小技巧有哪些
    这篇文章主要介绍“编写现代JavaScript代码的小技巧有哪些”,在日常操作中,相信很多人在编写现代JavaScript代码的小技巧有哪些问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望...
    99+
    2022-10-19
  • 不用备案的cdn有哪些特点
    1、无需备案相对于需要备案的CDN,不用备案的CDN可以省去备案过程,快速启用服务,节省时间和成本。2、价格相对较低不用备案的CDN...
    99+
    2023-05-13
    不用备案的cdn cdn
  • CSS代码书写顺序知识点有哪些
    这篇文章主要介绍“CSS代码书写顺序知识点有哪些”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“CSS代码书写顺序知识点有哪些”文章能帮助大家解决问题。 这里推荐...
    99+
    2022-10-19
  • 可以编写javascript代码的软件有哪些
    小编给大家分享一下可以编写javascript代码的软件有哪些,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!可以编写javascript代码的软件:Webstor...
    99+
    2023-06-15
  • html中if判断浏览器版本代码有哪些
    小编给大家分享一下html中if判断浏览器版本代码有哪些,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!<!--[if&nb...
    99+
    2022-10-19
  • 实用的HTML特效代码有哪些
    这篇文章主要介绍实用的HTML特效代码有哪些,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!   1。忽视右键   <body>   或   <body st...
    99+
    2022-10-19
  • 实用JavaScript代码片段有哪些
    实用JavaScript代码片段有哪些,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。1. 下载一个excel文档同时适用于wo...
    99+
    2022-10-19
  • css3中显示隐藏特效代码有哪些
    这篇文章主要介绍了css3中显示隐藏特效代码有哪些,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。 代码:1、“d...
    99+
    2022-10-19
  • 好用的JavaScript代码片段有哪些
    这篇文章主要为大家展示了“好用的JavaScript代码片段有哪些”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“好用的JavaScript代码片段有哪些”这篇文...
    99+
    2022-10-19
  • 实用的JavaScript单行代码有哪些
    这篇“实用的JavaScript单行代码有哪些”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“实用的JavaScript单行代...
    99+
    2023-07-05
  • javascript代码的使用方式有哪些
    这篇文章给大家分享的是有关javascript代码的使用方式有哪些的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。javascript代码有两种使用方式,分别是:1、直接执行,打开一个网页时,所有定义在script...
    99+
    2023-06-15
  • 写代码用用到的IDEA插件有哪些
    本篇内容主要讲解“写代码用用到的IDEA插件有哪些”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“写代码用用到的IDEA插件有哪些”吧!以下插件可以直接在 IDE...
    99+
    2022-10-19
  • 不用实名的云服务器租用有哪些特点
    不用实名的云服务器租用特点有:1、扩展性好,能有效解决传统物理主机与VPS服务中存在的管理难度大、业务扩展性弱的问题;2、能进行远程管理维护,实现云服务器之间的完全隔离,且内置共享存储和智能备份;3、具有快速供应和部署的能力,支持平滑扩展,...
    99+
    2022-10-10
  • html中的标准写法与dreamweaver生成代码有哪些不一样
    小编给大家分享一下html中的标准写法与dreamweaver生成代码有哪些不一样,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!   代码如下:   <!--doctype指定文...
    99+
    2022-10-19
  • JavaScript中有哪些语法和代码结构
    JavaScript中有哪些语法和代码结构?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。JavaScript的作用是什么1、能够嵌入动态文本于HTML页面。2、对浏览器事件做出...
    99+
    2023-06-14
  • 开发中常用的JavaScript单行代码有哪些
    这篇文章主要介绍开发中常用的JavaScript单行代码有哪些,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!1.强制布尔值要将变量强制转换为布尔值而不更...
    99+
    2022-10-19
软考高级职称资格查询
推荐阅读
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作