小米技术社区
小米技术社区管理员 关于小米

27岁,山西运城人,职业电商经理人,前端开发工作者,从事过网站建设、网络推广、SEO、SEM、信息流推广、二类电商、网络运维、软件开发,等相关电商工作,经验较为丰富,小米技术社区致力于为广大从事Web前端开发的人员提供一些力所能及的引导和帮助 ...[更多]

E-mail:mzze@163.com

Q Q:32362389

W X:xiaomi168527

小米介绍

小米技术社区大牛王飞 关于王飞

27岁,山西运城人,职业电商经理人,网络工程师兼运维,从事过运营商网络建设,企业网络建设、优化。数据中心网络维护等通过,经验丰富,座右铭:当自己休息的时候,别忘了别人还在奔跑。 ...[更多]

E-mail:wf_live@126.com

Q Q:3940019

微博:王小贱ss

小米技术社区设计小艳 关于小艳

大于花一样的年龄,河南郑州是我家,2010年在北京接触团购网,2011年进入天猫淘宝一待就是四年,如今已经将设计走向国际化(ps:误打误撞开始进入阿里巴巴国际站的设计,嘿嘿)五年电商设计,丰富经验,从事过天猫淘宝阿里各项设计,店铺运营,产品拍摄;我将我的经历与您分享是我的快乐!座右铭:越努力越幸运! ...[更多]

E-mail:97157726@qq.com

Q Q:97157726

标签云
精品推荐
  • 什么是闭包?js闭包的2个最大用途以及注意事项

    什么是闭包?js闭包的2个最大用途以及注意事项

    各种专业文献上的"闭包"(closure)定义非常抽象,很难看懂。简单的说,闭包就是能够读取其他函数内部变量的函数。由于在Javascript语言中,只有函数内部的子函数才能读取局部变量,因……
    84人已经看过了
您的位置:首页 > 前端开发 > Javascript > 原生JS

3第四阶段11 js逻辑表达式和逻辑运算符以及空值合并运算、且、或、取反

分类: 原生JS20个赞


/* let userName = prompt(); //输入框
if(userName="admin"){
    alert("登录成功!");
    console.log("登录成功了");
} */

if(0){
    //会不会被执行  结果不会 0为假
    console.log("你猜")
}
if(1){
    //会不会被执行  结果会 1为真
    console.log("你再猜")
}
else{

}
// 逻辑表达式  问号?
/* let rel = age>18 ? true:false;
if(rel) {
    //进入夜场 才能买才酒和烟
} */

//逻辑运算符  且 &&  或|| 非 !
//1.或运算
/* false || false  = false;
true || false =true;
false || true =true;
ture || true = true; */
//逻辑运算符一直在找一个真值,找到后就返回这个真值的第一个,如果没找到就返回最后一个值
//短路求值  找到真的后后面的不再理货
console.log(0|| undefined || null ||NaN || 1 || 2);
let a1 =""
let b1 =""
let c1="花花"
console.log(a1 || b1||c1||"这家伙很懒,什么都没输入")

//2.且运算 也叫于运算 &&  ,找一个一个假值就返回
//且一直在寻找一个假值,而或一直在寻找一个真值 
/* true && true = true;
true && false =false;
false && true =true;
false && false = false; */

//3.且&& 和 或 ||谁的 优先级更高?

// a&&b || c&&d = (a&&b) || (c&&d) 
// 可以查 javascript 运算符优先级 ,如果记不住就加括号

// 4.取反 !   !true =false  !false =true
/* let a2;
console.log(a2); //结果为未定义 undifined
let b2=!a2;
console.log(b2) //结果为true
console.log(!!null)  //经常用 null先!null会变成逻辑值, 两个!!null会得到他本身的逻辑值  在插入数据库语句经常用 
function insert(sql){
    let obj = db.insert({name:"XXX"});
    return !!obj 
} */
//5.空值合并运算 和||有点像  经常用  主要在赋值上,判定是不是null和unddfiend
let a4;
let b4 =10;
let x = a4??b4; //结果10,  用||的结果也是10
console.log(x) 
// 用??和||的区别  ??不转换数据,而||转换
// x=a4??b4  可以分解为 x=(a4 ==null && a4==undefiend) ? a4:b4 结果为10  他是看a4是不是null和undefiend,如果是结果就是A4,如果不是就是B4
//而 ||的写法的意思是 先把a4=undifiend转换为a4=false=0, 在 a4||b4 结果为10


<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <script>
        //判断分数送东西
       /*  let score = prompt("请输入分数");
        if(score==100){
            alert("兰博基尼");
        }else if(score>=90 && score<100){
            alert("法拉利");
        }else if(score>=80 && score <90){
            alert("宝马");
        }else {  
            alert("你的分数太低,啥都没有")
        } */
        //判断年龄 逻辑表达式写,等于if else
        let age = prompt("请输入你的年龄");
        let message = (age<3) ? "HI!宝贝":
        (age<=18) ? "hello":
        (age<=100) ? "你好":"您高寿..."
        alert(message);
    </script>
</head>
<body>
    
</body>
</html>


小米技术社区