溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

你試過不用if擼代碼嗎?

發(fā)布時間:2020-06-22 00:23:50 來源:網(wǎng)絡(luò) 閱讀:228 作者:Fundebug 欄目:web開發(fā)

譯者按: 試著不用if擼代碼,是件很有趣的事,而且,萬一你領(lǐng)會了什么是“數(shù)據(jù)即代碼,代碼即數(shù)據(jù)”呢?

  • 原文: Coding Tip: Try to Code Without If-statements
  • 譯者: Fundebug

為了保證可讀性,本文采用意譯而非直譯。另外,本文版權(quán)歸原作者所有,翻譯僅用于學(xué)習(xí)。

我在教新手編程時,喜歡給他們一些小小的挑戰(zhàn),比如:不使用if語句(或者三元運算符、switch語句等)解決一些編程問題。

這樣做有什么意義嗎?

事實上,它可以迫使你從不同的角度尋找解決方法,也許可以找到更好的方法。

當(dāng)然,使用if語句沒有任何不對的地方。但是,不使用if的話,有時候可以增加代碼的可讀性。這一點并不是絕對的,如果完全不使用if語句的話,代碼可讀性也許會更差。這需要你根據(jù)不同情況去判斷。

而且,不用if的話不只是影響可讀性。在這背后隱含著更加深刻的道理。通過了解本文的代碼示例,你可以發(fā)現(xiàn),如果不使用if語句的話,你的代碼會更加接近代碼即數(shù)據(jù)的概念。

另外,當(dāng)你嘗試不使用if語句去編程時,也是一件非常有意思的事情。

示例1: 統(tǒng)計數(shù)組中的奇數(shù)

假設(shè)我們有一個整數(shù)數(shù)組arrayOfIntegers,現(xiàn)在需要統(tǒng)計其中奇數(shù)的個數(shù):

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);
不用if
let counter = 0;

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

console.log(counter);

不用if時,我們巧妙地利用了奇數(shù)與偶數(shù)的特性,它們除以2的余數(shù)分別是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()));

你是否發(fā)現(xiàn)if語句中其實隱含著一些信息呢?它告訴我們哪一天是周末,哪一天是工作日。因此,要去掉if語句的話,我們只需要把這些信息寫入weekendOrWeekday.labels對象,然后直接使用它就好了。

廣告: 如果你需要監(jiān)控線上JavaScript代碼的錯誤的話,歡迎免費使用Fundebug!

示例3: doubler函數(shù)

寫一個doubler函數(shù),它會根據(jù)參數(shù)的類型,進行不同的操作:

  • 如果參數(shù)是數(shù)字,則乘以2(i.e. 5 => 10, -10 => -20);
  • 如果參數(shù)是字符串,則每個字符重復(fù)2次 (i.e. 'hello' => 'hheelloo');
  • 如果參數(shù)是函數(shù),則調(diào)用2次;
  • 如果參數(shù)是數(shù)組,則將每一個元素作為參數(shù),調(diào)用doubler函數(shù)
  • 如果參數(shù)是對象,則將每個屬性值作為參數(shù),調(diào)用doubler函數(shù)
使用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;
  },
};

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');
  }),
);

可知,我將每一種參數(shù)類型對應(yīng)的操作綁定到了doubler.operationsByType,這樣不需要switch語句,就可以實現(xiàn)doubler函數(shù)了。

關(guān)于Fundebug

Fundebug專注于JavaScript、微信小程序、微信小游戲、支付寶小程序、React Native、Node.js和Java實時BUG監(jiān)控。 自從2016年雙十一正式上線,F(xiàn)undebug累計處理了8億+錯誤事件,得到了Google、360、金山軟件、百姓網(wǎng)等眾多知名用戶的認(rèn)可。歡迎免費試用!

你試過不用if擼代碼嗎?

版權(quán)聲明

轉(zhuǎn)載時請注明作者Fundebug以及本文地址:
https://blog.fundebug.com/2017/11/06/write-javascript-without-if/

向AI問一下細節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI