跳到主要内容

JavaScript if 语句

在程序中 if 语句属于条件语句的一种。

如同 if 的本意,就是根据条件做不同的事情。

1. 基本语法

if 语句的最基本语法如下:

// 方式1
if (条件) {
// 条件满足做的事情;
}

// 方式2
if (条件) 条件满足时候做的事情;

通常方式2的使用场景是在条件满足时只会写一行代码的情况,有些代码压缩工具可能会将多个语句配合逗号表达式压缩成方式2。

这是 if 语句两种最基本语法。

第一种方式用到的相对较多,当条件满足的时候,就会执行大括号内的代码,第二种方式则会在条件满足的时候执行括号后面到行尾的语句。

条件满足的情况其实就是条件的执行结果不为false或者不能被隐式转为false的情况。

var score = 99;

if (score > 60) {
console.log('及格了'); // 输出:"及格了"
}

if (score > 90) {
console.log('优秀!'); // 输出:"优秀!"
}

>符号就是判断左边的数是否大于右边,如果左边大于右边则会返回 true,否则返回 false

这里两个 if 语句的条件都是满足的,所以会输出及格了优秀!

方式二在简单函数中很常见

// 计算圆面积
function calcArea(r) {
if (!r) return 0;

return r * r * 3.14;
}

这里判断了 r 是否有传入,如果没有传入则直接返回了 0。

2. 分支

if 语句可以仅有单个分支也可以有多个分支。

// 单个分支
if (条件1) {
// 条件1满足的时候执行的代码
} else {
// 条件1不满足的时候执行的代码
}

// 多个分支
if (条件1) {
// 条件1满足的时候执行的代码
} else if (条件2) {
// 条件2满足的时候执行的代码
} else if (条件3) {
// 条件3满足的时候执行的代码
} else {
// 条件1、条件2、条件3都不满足的时候执行
}

单个分支的方式比较常用:

var score = 77;

if (score >= 60) {
console.log('及格了');
} else {
console.log('不及格');
}

// 输出:"及格了"

>=则表示左边的值如果大于等于右边的值,则返回 true 否则返回 false

通过这样的分支,就可以扩展条件的场景。

多个分支的场景也非常用到,如需要判断成绩的不同区间给出不同的标准:

var score = 88;

if (score < 60) {
console.log('不及格');
} else if (score < 80) {
console.log('良好');
} else if (score < 90) {
console.log('优秀!');
} else {
// 剩下的肯定是大于等于九十的情况
console.log('太强了!');
}

// 输出:"优秀!"

在多个分支的情况下,else 也可以不提供。

var score = 0;

if (score < 60) {
console.log('不及格');
} else if (score < 80) {
console.log('良好');
} else if (score < 90) {
console.log('优秀!');
} else if (score <= 100) {
console.log('太强了!');
}

// 输出:不及格

3. 例子

注意:例子的解法不止一种,可以自己发散实现

3.1 判断一个数是不是偶数

var num = 77;

if (num % 2 === 0) {
console.log(num + '是一个偶数');
} else {
console.log(num + '是一个奇数');
}

// 输出:77是一个奇数

这里就是通过将数字对 2 进行取余数操作,如果余数是 0 则说明一个数是偶数,否则就是奇数。

3.2 计算成人的标准体重

var sex = '男';
var height = 178;

var offset = 0;
if (sex === '男') {
offset = 105;
} else {
offset = 100;
}

var weight = height - offset;

console.log('身高为' + height + 'cm的' + sex + '性标准体重为' + weight + 'KG');

// 输出:身高为178cm的男性标准体重为73KG

首先要知道标准体重的计算公式:

  • 男:身高(cm)-105 = 标准体重(kg)
  • 女:身高(cm)-100 = 标准体重(kg)

可以看到男生需要身高减去一个 105 的偏移量,女生需要减去 100 的偏移量,所以要判断性别决定这个值。

每个人的身高是不一样的,所以作为变量。

所以只需要根据性别判断是减去 105 还是减去 100,最后计算出结果即可。

4. 小结

if 语句很简单,但是非常常用和重要,高级语言如果失去了条件语句,又没有其他的替代品,基本就失去了活力。

使用if语句的时候也需要注意,碰到冗长的条件尽量思考一下是不是有更好的解决方案,防止代码可读性和可维护性变差。