codecamp

Making decisions in your code — conditionals

先决条件: 基本的计算机素养,对HTML和CSS的基本了解, JavaScript第一步
目的: 了解如何在JavaScript中使用条件结构。

你可以有一个条件..!

人类(和其他动物)在影响他们生活的所有时间做决定,从小("我应该吃一个饼干还是两个?")到大("我应该留在我的祖国,在我父亲的农场工作, 我应该搬到美国,研究天体物理学吗?")

条件语句允许我们在JavaScript中表示这样的决策,从必须做出的选择(例如"一个或两个")到所得到的结果或那些选择(或许"吃一个cookie"的结果可能是"仍然 感觉饥饿","吃两个饼干"的结果可能"感觉充满了,但妈妈骂我吃所有的饼干"。)

if ... else语句

让我们来看看你将在JavaScript中使用的最常见类型的条件语句 - 谦逊 /Statements/if...else\">if ... else 语句/ if ... else">语句

基本if ... else语法

基本 if ... else 语法如下所示: pseudocode :

if (condition) {
  code to run if condition is true
} else {
  run some other code instead
}

这里我们有:

  1. The keyword if followed by some parentheses.
  2. A condition to test, placed inside the parentheses (typically "is this value bigger than this other value", or "does this value exist"). This condition will make use of the comparison operators we discussed in the last module, and will return true or false.
  3. A set of curly braces, inside which we have some code — this can be any code we like, and will only be run if the condition returns true.
  4. The keyword else.
  5. Another set of curly braces, inside which we have some more code — this can be any code we like, and will only be run if the condition is not true.

此代码是非常易读的 - 它是说"如果 条件返回 true ,运行代码A, >运行代码B"

你应该注意,你不必包括 else 和第二个花括号块 - 以下也是完美的法律代码:

if (condition) {
  code to run if condition is true
}

run some other code

但是,你需要在这里小心 - 在这种情况下,第二个代码块不受条件语句控制,所以它将总是运行,无论条件是否返回 true / code>或 false 。 这不一定是坏事,但它可能不是你想要的 - 通常你会想运行一个代码块另一个,而不是两者。

作为最后一点,有时可能会看到 if ... else 语句写入没有花括号,以下面的缩写样式:

if (condition) code to run if condition is true
else run some other code instead

这是完全有效的代码,但是不推荐使用它 - 更容易阅读代码,并解决发生了什么,如果你使用花括号来分隔代码块,并使用多行和缩进。

一个真正的例子

为了更好地理解这个语法,让我们考虑一个真实的例子。 想象一个孩子被他们的母亲或父亲请求帮忙做家务。 父母可能会说"嗨甜心,如果你帮助我去购物,我会给你一些额外的津贴,所以你可以买得起你想要的玩具。 在JavaScript中,我们可以这样表示:

var shoppingDone = false;

if (shoppingDone === true) {
  var childsAllowance = 10;
} else {
  var childsAllowance = 5;
}

如图所示的代码总是导致 shoppingDone 变量返回 false ,这意味着我们可怜的孩子会失望。 如果孩子做了购物,那么应该由我们提供一个机制让父母将 shoppingDone 变量设置为 true

注意:您可以查看更多 ="external">此示例的完整版本在GitHub (也看到它 running live 。)

否则if

最后一个例子为我们提供了两个选择或结果 - 但是如果我们想要两个以上呢?

有一种方法可以将额外的选择/结果链接到你的 if ... else - 使用 else if 。 每个额外的选择需要一个额外的块放在 if(){...} else {...} 之间 - 检查下面更多涉及的例子, 可以是简单的天气预报应用程序的一部分:

<label for="weather">Select the weather type today: </label>
<select id="weather">
  <option value="">--Make a choice--</option>
  <option value="sunny">Sunny</option>
  <option value="rainy">Rainy</option>
  <option value="snowing">Snowing</option>
  <option value="overcast">Overcast</option>
</select>

<p></p>
var select = document.querySelector('select');
var para = document.querySelector('p');

select.addEventListener('change', setWeather);

function setWeather() {
  var choice = select.value;

  if (choice === 'sunny') {
    para.textContent = 'It is nice and sunny outside today. Wear shorts! Go to the beach, or the park, and get an ice cream.';
  } else if (choice === 'rainy') {
    para.textContent = 'Rain is falling outside; take a rain coat and a brolly, and don\'t stay out for too long.';
  } else if (choice === 'snowing') {
    para.textContent = 'The snow is coming down — it is freezing! Best to stay in with a cup of hot chocolate, or go build a snowman.';
  } else if (choice === 'overcast') {
    para.textContent = 'It isn\'t raining, but the sky is grey and gloomy; it could turn any minute, so take a rain coat just in case.';
  } else {
    para.textContent = '';
  }
}

  1. Here we've got an HTML <select> element allowing us to make different weather choices, and a simple paragraph.
  2. In the JavaScript, we are storing a reference to both the <select> and <p> elements, and adding an event listener to the <select> element so that when its value is changed, the setWeather() function is run.
  3. When this function is run, we first set a variable called choice to the current value selected in the <select> element. We then use a conditional statement to show different text inside the paragraph depending on what the value of choice is. Notice how all the conditions are tested in else if() {...} blocks, except for the first one, which is tested in an if() {...} block.
  4. The very last choice, inside the else {...} block, is basically a "last resort" option — the code inside it will be run if none of the conditions are true. In this case, it serves to empty the text out of the paragraph if nothing is selected, for example if a user decides to re-select the "--Make a choice--" placeholder option shown at the beginning.

关于比较运算符的注释

比较运算符用于测试条件语句中的条件。 我们首先查看了 JavaScript - 数字和运算符的基本数学文章中的比较运算符。 我们的选择是:

  • === and !== — test if one value is identical to, or not identical to, another.
  • < and > — test if one value is less than or greater than another.
  • <= and >= — test if one value is less than or equal to, or greater than or equal to, another.

Note: Review the material at the previous link if you want to refresh your memories on these.\">

我们想特别提到测试布尔( true / false )值,以及一个常见的模式,你会反复遇到。 任何不是 false undefined null 0 NaN 或者测试为条件语句时,空字符串(\'\')实际返回 true ,因此您可以简单地使用变量名来测试它是否 > true ,或者甚至它存在(即它不是未定义的。)所以例如:

var cheese = 'Cheddar';

if (cheese) {
  console.log('Yay! Cheese available for making cheese on toast.');
} else {
  console.log('No cheese on toast for you today.');
}

并且,回到我们以前的例子,关于孩子为他们的父母做杂事,你可以这样写:

var shoppingDone = false;

if (shoppingDone) { // don't need to explicitly specify '=== true'
  var childsAllowance = 10;
} else {
  var childsAllowance = 5;
}

嵌套if ... else

将一个如果... else 语句放在另一个 - 中来嵌套它是完全正确的。 例如,我们可以更新我们的天气预报应用程序,根据温度是什么显示更多的选择:

if (choice === 'sunny') {
  if (temperature < 86) {
    para.textContent = 'It is ' + temperature + ' degrees outside — nice and sunny. Let\'s go out to the beach, or the park, and get an ice cream.';
  } else if (temperature >= 86) {
    para.textContent = 'It is ' + temperature + ' degrees outside — REALLY HOT! If you want to go outside, make sure to put some suncream on.';
  }
}

即使代码一起工作,每个 if ... else 语句完全独立于另一个工作。

逻辑运算符:AND,OR和NOT

如果要测试多个条件而不编写嵌套的 if ... else 语句, / Operators / Logical_Operators">逻辑运算符可以帮助您。 当在条件下使用时,前两个操作如下:

  • && — AND; allows you to chain together two or more expressions so that all of them have to individually evaluate to true for the whole expression to return true.
  • || — OR; allows you to chain together two or more expressions so that one or more of them have to individually evaluate to true for the whole expression to return true.

为了给你一个AND示例,上面的示例代码片段可以重写为:

if (choice === 'sunny' && temperature < 86) {
  para.textContent = 'It is ' + temperature + ' degrees outside — nice and sunny. Let\'s go out to the beach, or the park, and get an ice cream.';
} else if (choice === 'sunny' && temperature >= 86) {
  para.textContent = 'It is ' + temperature + ' degrees outside — REALLY HOT! If you want to go outside, make sure to put some suncream on.';
}

因此,例如,第一代码块将仅在 choice ===\'sunny\' temperature 86 return true

让我们来看一个快速的OR例子:

if (iceCreamVanOutside || houseStatus === 'on fire') {
  console.log('You should leave the house quickly.');
} else {
  console.log('Probably should just stay in then.');
}

运算符表示的最后一种类型的逻辑运算符NOT可用于否定表达式。 让我们在上面的例子中结合OR:

if (!(iceCreamVanOutside || houseStatus === 'on fire')) {
  console.log('Probably should just stay in then.');
} else {
  console.log('You should leave the house quickly.');
}

在这个片段中,如果OR语句返回 true ,则NOT运算符将否定它,以便整个表达式返回 false

您可以在任何结构中将任意数量的逻辑语句组合在一起。 以下示例仅在两个OR语句都返回true的情况下执行代码,这意味着总体AND语句将返回true:

if ((x === 5 || y > 3 || z <= 10) && (loggedIn || userName === 'Steve')) {
  // run the code
}

在条件语句中使用逻辑OR运算符时常见的错误是尝试说明其值要被检查一次的变量,然后给出一个值列表,它可以返回true,由 || >(OR)运算符。 例如:

if (x === 5 || 7 || 10 || 20) {
  // run my code
}

在这种情况下, if(...)中的条件将始终评估为true,因为7(或任何其他非零值)总是评估为true。 这个条件实际上是说"如果x等于5,或7是真的 - 它总是"。 这在逻辑上不是我们想要的! 要进行这项工作,你必须在每个OR运算符的每一侧指定一个完整的测试:

if (x === 5 || x === 7 || x === 10 ||x === 20) {
  // run my code
}

switch语句

if ... else 语句完成启用条件代码的工作,但他们不是没有他们的缺点。 它们主要适用于您有几个选择的情况,每个都需要合理数量的代码运行,和/或条件复杂(例如多个逻辑运算符)。 对于只想根据条件设置变量为某个值或打印特定语句的情况,语法可能有点繁琐,尤其是如果您有大量选择。

switch 语句是您的朋友, 它们将单个表达式/值作为输入,然后查看多个选项,直到找到与该值匹配的值,并执行相应的代码。 这里有一些伪代码,给你一个想法:

switch (expression) {
  case choice1:
    run this code
    break;

  case choice2:
    run this code instead
    break;
    
  // include as many cases as you like

  default:
    actually, just run this code
}

这里我们有:

  1. The keyword switch, followed by a set of parentheses.
  2. An expression or value inside the parentheses.
  3. The keyword case, followed by a choice that the expression/value could be, followed by a colon.
  4. Some code to run if the choice matches the expression.
  5. A break statement, followed by a semi-colon. If the previous choice matches the expression/value, the browser stops executing the code block here, and moves on to any code that appears below the switch statement.
  6. As many other cases (bullets 3–5) as you like.
  7. The keyword default, followed by exactly the same code pattern as one of the cases (bullets 3–5), except that default does not have a choice after it, and you don't need to break statement as there is nothing to run after this in the block anyway. This is the default option that runs if none of the choices match.

注意:您不必包含默认部分 - 如果表达式没有机会等于未知值,您可以安全地忽略该部分。 如果有机会,但是,你需要包括它来处理未知的情况。

一个开关示例

让我们看一个真实的例子 - 我们将重写我们的天气预报应用程序,使用switch语句:

<label for="weather">Select the weather type today: </label>
<select id="weather">
  <option value="">--Make a choice--</option>
  <option value="sunny">Sunny</option>
  <option value="rainy">Rainy</option>
  <option value="snowing">Snowing</option>
  <option value="overcast">Overcast</option>
</select>

<p></p>
var select = document.querySelector('select');
var para = document.querySelector('p');

select.addEventListener('change', setWeather);


function setWeather() {
  var choice = select.value;

  switch (choice) {
    case 'sunny':
      para.textContent = 'It is nice and sunny outside today. Wear shorts! Go to the beach, or the park, and get an ice cream.';
      break;
    case 'rainy':
      para.textContent = 'Rain is falling outside; take a rain coat and a brolly, and don\'t stay out for too long.';
      break;
    case 'snowing':
      para.textContent = 'The snow is coming down — it is freezing! Best to stay in with a cup of hot chocolate, or go build a snowman.';
      break;
    case 'overcast':
      para.textContent = 'It isn\'t raining, but the sky is grey and gloomy; it could turn any minute, so take a rain coat just in case.';
      break;
    default:
      para.textContent = '';
  }
}

注意:您也可以 external">在GitHub上找到此示例(请参阅 ">运行live 也有)。

三元运算符

在我们让你玩一些例子之前,有一个最后一点语法我们想介绍给你。 三元或条件运算符是一小部分语法,用于测试 条件并返回一个值/表达式,如果它是 true ,另一个如果是 false - 这在某些情况下可能是有用的,并且可以占用少得多的代码比 如果你只需要通过 true / false 条件选择两个选项,那么 if ... else 伪代码如下所示:

( condition ) ? run this code : run this code instead

让我们来看一个简单的例子:

var greeting = ( isBirthday ) ? 'Happy birthday Mrs. Smith — we hope you have a great day!' : 'Good morning Mrs. Smith.';

这里我们有一个变量 Birthday - 如果这是 true ,我们给客人一个生日快乐消息; 如果没有,我们给她标准的每日问候。

三元运算符示例

你不必只用三元运算符设置变量值; 你也可以运行函数,或代码行 - 任何你喜欢的。 以下实例显示了一个简单的主题选择器,其中使用三元运算符应用网站的样式。

<label for="theme">Select theme: </label>
<select id="theme">
  <option value="white">White</option>
  <option value="black">Black</option>
</select>

<h1>This is my website</h1>
var select = document.querySelector('select');
var html = document.querySelector('html');
document.body.style.padding = '10px';

function update(bgColor, textColor) {
  html.style.backgroundColor = bgColor;
  html.style.color = textColor;
}

select.onchange = function() {
  ( select.value === 'black' ) ? update('black','white') : update('white','black');
}

这里有一个 < select> >元素来选择主题(黑色或白色),以及一个简单的 < h1> 以显示网站标题。 我们还有一个称为 update()的函数,它使用两种颜色作为参数(输入)。 网站的背景颜色设置为第一个提供的颜色,其文本颜色设置为第二个提供的颜色。

最后,我们还有一个 onchange 事件侦听器,用于运行 函数包含三元运算符。 它从测试条件开始 - select.value ===\'black\'。 如果这返回 true ,我们运行带有黑色和白色参数的 update()函数,这意味着我们以黑色的背景颜色和白色的文本颜色结束。 如果它返回 false ,我们运行 update()函数,参数为白色和黑色,这意味着网站颜色被反转。

注意:您也可以 external">在GitHub上找到此示例(请参阅 ">运行live 也有)。

主动学习:一个简单的日历

在这个例子中,你将帮助我们完成一个简单的日历应用程序。 在代码中,你有:

  • A <select> element to allow the user to choose between different months.
  • An onchange event handler to detect when the value selected in the <select> menu is changed.
  • A function called createCalendar() that draws the calendar and displays the correct month in the <h1> element.

我们需要你在 onchange 处理函数中写一个条件语句,就在 // ADD CONDITIONAL HERE 下面。 这应该:

  1. Look at the selected month (stored in the choice variable. This will be the <select> element value after the value changes, so "January" for example.)
  2. Set a variable called days to be equal to the number of days in the selected month. To do this you'll have to look up the number of days in each month of the year. You can ignore leap years for the purposes of this example.

提示:

  • You are advised to use logical OR to group multiple months together into a single condition; many of them share the same number of days.
  • Think about which number of days is the most common, and use that as a default value.

如果出错,您可以随时使用"重置"按钮重置示例。 如果你真的卡住,按"显示解决方案"看到一个解决方案。

主动学习:更多颜色选择!

在这个例子中,你将使用我们前面看到的三元运算符示例,并将三元运算符转换为switch语句,这将允许我们对简单网站应用更多的选择。 查看 < select> - 这 时间,你会看到它没有两个主题选项,但五。 您需要在 // ADD SWITCH STATEMENT 注释下面添加一个switch语句:

  • It should accept the choice variable as its input expression.
  • For each case, the choice should equal one of the possible values that can be selected, i.e. white, black, purple, yellow, or psychedelic.
  • For each case, the update() function should be run, and be passed two color values, the first one for the background color, and the second one for the text color. Remember that color values are strings, so need to be wrapped in quotes.

如果出错,您可以随时使用"重置"按钮重置示例。 如果你真的卡住,按"显示解决方案"看到一个解决方案。

结论

这就是你真正需要知道的JavaScript中的条件结构现在! 我相信你会理解这些概念,轻松地完成这些例子; 如果您有任何不明白的地方,请随时阅读本文,或与我们联系以寻求帮助。

也可以看看

JavaScript building blocks
循环吧代码
温馨提示
下载编程狮App,免费阅读超1000+编程语言教程
取消
确定
目录
CSS

关闭

MIP.setData({ 'pageTheme' : getCookie('pageTheme') || {'day':true, 'night':false}, 'pageFontSize' : getCookie('pageFontSize') || 20 }); MIP.watch('pageTheme', function(newValue){ setCookie('pageTheme', JSON.stringify(newValue)) }); MIP.watch('pageFontSize', function(newValue){ setCookie('pageFontSize', newValue) }); function setCookie(name, value){ var days = 1; var exp = new Date(); exp.setTime(exp.getTime() + days*24*60*60*1000); document.cookie = name + '=' + value + ';expires=' + exp.toUTCString(); } function getCookie(name){ var reg = new RegExp('(^| )' + name + '=([^;]*)(;|$)'); return document.cookie.match(reg) ? JSON.parse(document.cookie.match(reg)[2]) : null; }