【条件语句控制表达式】

条件语句控制表达式

运算符及表达式

  • ()前面不能直接写++

    console.log(++a + a++); //24    //() 不能跟 ++ 一起用
    
  • 字符串和数值进行比较(字符串会自动转为数值)

    //字符串和数值进行比较
    console.log(1 > 2); //false
    console.log('123' > 123); //false 自动转number
    console.log('123A' > 123); //false 自动转number,如果不能转就会出现NaN
    
  • 出现NaN一般都是false

    console.log(NaN == NaN); //false
    
  • undefinde是null的派生所以对应的值是相当的

    //undefined 和 null的派生子类 和 null
    console.log(undefined == null); //true
    console.log(undefined === null); //false
    
  • 字符串和字符串比较(根据ASCII码 A65 a96 自动进行ASSCII码比较 但是是比较第一位)

    //字符串和字符串比较(根据ASCII码 A65 a96 自动进行ASSCII码比较 但是是比较第一位)
    console.log('a' > 'b'); //flase
    console.log('a' < 'b'); //true
    console.log('bAA' < 'azz'); //false
    
  • 布尔类型的值和null进行比较

    //boolean类型的值和null进行比较 自动转数值(出现NaN是false)
    console.log(true > null); //true
    console.log(true); //true
    console.log(true > undefined); //false
    
  • 转换会先转换再进行比较

    //恒等 这俩个内容是一个内容
    console.log(Number(true) == 1); //true
    console.log(Number(true) === 1); //true
    console.log(Number(0) == false); //true
    
  • null值及undefined跟0进行比较

    //undefined和0进行比较
    console.log(undefined == 0); //NaN false
    //null是空对象引用 对应的是一个引用类型 引用类型比较的是地址
    console.log(null == 0); //false
    

    逻辑运算符

//逻辑运算符 && 短路与 &断路与 ||短路 或 |断路或!
//&& 所有的同时满足才为真 && 只要前面有一个是假后面的就不会看了 &看完全部
var a = 10,
    b = 20,
    c = 30;
console.log(a > b && b < c); //false
console.log(c > b && b < c); //true
// ||有一个是true就是true  前面只要出现了ture 就不看后面的  |看完全部
console.log(c > b || a > b); //true
//! 取反
console.log(!c > b || a > b); //flase
console.log(!(c > b || a > b)); //flase
// || 常用 有一个是ture 取true
console.log(a > b || 20); //true    //20
var i = 0 || 10
console.log(i); //10
//如果俩个都是false 取最后一个
var str = undefined || ''
console.log(str); //'' 空字符串
//如果俩个都是true的情况下 取第一个位true的结果
var str1 = "A" || "B"
console.log(str1); //A 短路操作
var str2 = "" || 'false' || 'true'
console.log(str2); //false
//三目运算 逻辑运算的优先级会高于三目运算符
var str3 = (10 > 20 ? '' : '123') || (30 > 20 ? '' : '456')
console.log(str3); //123
//如果出现false 直接取false 如果全是true 取最后一个
var str4 = 10 && 20;
console.log(str4); //20
var str5 = undefined && ''
console.log(str5); //undefined
//转成boolean类型
var str6 = !123
console.log(str6); //false
//相当于将对应的boolean类型表达式解析出对应的值
console.log(20 > 30 || 30 < 20); //false
console.log(false || false); //false
console.log(20 > 30 || 20); //20
console.log(false || 20); //20
console.log(0 || 20);//20

表达式的概念:

由运算符和操作数(变量或常量)组成的式子

  • 算术运算符组成的式子叫算术表达式, 如:2+3;
  • 关系运算符组成的式子叫关系表达式或者条件表达式, 如:a>5;
  • 逻辑运算符组成的式子叫做逻辑表达式, 如:a&&b

运算符优先级(从上到下执行)

运算符描述
. [] ()对象成员存取、数组下标、函数调用等
++ – ~ ! delete new typeof void一元运算符
*** / %**乘法、除法、去模
+ - +加法、减法、字符串连接
<< >> >>>移位
< <= > >= instanceof关系比较、检测类实例
== != === !==恒等(全等)
&位与
^位异或
|位或
&&逻辑与
||逻辑或
?:三元条件
= x=赋值、运算赋值
,多重赋值、数组元素

程序控制语句(所有程序、语言都有)

控制程序的执行(利用条件控制 利用循环来控制)

条件控制语句(只会进入其中一个条件)

if 如果(第一个条件)else if 如果(第二个条件 无限加)else 否则(只有一个 上面都不满足的情况下)

if 和 else if 同时满足的情况下 它只会进入第一个满足的条件

if (条件表达式(boolean类型的值,如果当前这个不是一个boolean类型的值它会自动转成boolean类型)){
	需要执行的代码
}else if(条件表达式){
	需要执行的代码
}else{//上面的都不满足的情况下
	需要执行的代码
}
var a=8,b=8;
//从上到下的顺序进行的 上面只有一个进入到下面的内容就不会执行了
if(a>b){
	console.log("我是a的值为"+a);
}else if(a==b){
	console.log("我是b的值为"+b);
}else{
	console.log("上面的都不满足");
}

一条执行语句可以省略{}, 多条时不能省略{}, 建议不管是一条还是多条都写上{}

条件嵌套

//保证良好的缩进 保证可读性
//求y的值
var x = prompt()
var y
//可能不是数值
//提取条件优秀级 先找出问题的条件 再找大的条件 再找小的条件
if (Number(x) || x == 0) {
if (x < 0) {
y = -1
} else if (x == 0) {
y = 0
} else {
y = 1
}
alert('当x的值为' + x + '时,' + 'y的值为' + y);
} else {
alert('您的输入有误!')
}

switch

switch属于对应的值判断 里面的是对应的表达式(产生对应的值)下面的case就是一个个的值选项

switch(表达式){
	case 值(是常量): 操作 break;
	case : break;
	case : break;
	default;当上面都不满足的情况下才执行默认的操作
}

实例

//指令系统 发送1吃饭 发送2玩游戏 发送3睡觉 发送4再来一次
var number = prompt('请输入指令');
//恒等判断 需要对应的类型和值一样
//需要加引号
switch (number) {
    case '1':
    case '5': //1和5干一样的事
        alert('准备吃饭');
    	break;
    case '2':
    	alert('准备玩游戏');
    	break;
    case '3':
    	alert('准备睡觉');
    	break;
    case '4':
        alert('再来一次');
        break;
    default:
    	alert('无该指令!');
}
//break跳出 跳出整个代码块 switch代码以及循环代码块
//如果没有break 从头走到底 会从满足条件的第一个走到default里面
//switch不能判断范围 只能对应的进行特定的值的判断
//if 判断范围 在一定区间内容进行判断(功能更加强大)

总结

  • if else else if 里面的代码只有一行可以省略{}
  • if 后面不一定要带else 或者else if
  • if 里面的表达式如果不是对应的boolean的表达式 它会强制转换为boolean类型(自动转换)
  • else 一定得是最后的 而且他是不带条件的
  • if 里面可以嵌套if 以及相关的内容(else else if都可以嵌套的)
  • switch 里面填写的表达式是会返回值 这个值一般是常量
  • switch 里面有case和对应的default case表示一个个的选项 对应的default表示默认选项
  • 多个case可以在一行书写表示对应的处理语句是一个
  • break 用于跳出整个代码块跳出switch (也可以跳出循环的代码块)
  • switch 必须要有规定的值的时候才用 它不会使用到有区间的内容(比对是恒等比对)
  • if 是可以使用区间值 也可以使用固定值
  • if 效率和switch效率 从一行代码区分对应的来说 if效率会高点 多行代码区分 switch效率会高(用空间换时间)
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值