IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> 短路运算(逻辑中断) -> 正文阅读

[JavaScript知识库]短路运算(逻辑中断)

短路运算(逻辑中断)

短路运算(逻辑中断):

当有多个表达式(值)时左边的表达式值可以确定结果时,就不再继续计算右边的表达式的值
我对短路运算(逻辑中断)的理解就是,就像家里面的家用电器,如果有一个短路跳闸,那么家里面全部的家用电器都不能用了

  1. 逻辑与:表达式1 && 表达式2
    如果第一个表达式的值为真,则返回表达式2(多个表达式亦如此)
    如果第一个表达式的值为假,则返回表达式1
    我对逻辑与的逻辑中断的理解就是,它是为了在多个表达式中找到假的那个表达式,如果找不到就返回最后一个表达式的值
        console.log('逻辑与的逻辑中断');
        console.log(0 && 123);          //0
        console.log(123 && 0 && 456);   //0
        console.log('' && 123);         //''
        console.log(1 && 2 * 9 && 666);   //666
        var num = 0;
        console.log(0 && num++);        //0
        console.log(num);               //0

在这里插入图片描述

  1. 逻辑或:表达式1 || 表达式2
    如果第一个表达式的值为真,则返回表达式1(多个表达式亦如此)
    如果第一个表达式的值为假,则返回表达式2
    我对逻辑或的逻辑中断的理解就是,它是为了在多个表达式中找到真的那个表达式,如果找不到就返回最后一个表达式的值
        console.log('逻辑或的逻辑中断');
        console.log(0 || 123);          //123
        console.log(123 || 0 || 456);   //123
        console.log('' || 123);         //123
        console.log(1 || 2 * 9 || 666);   //1
        var num = 0;
        console.log(0 || ++num);        //1  ++num是先自加后运算  num++是先运算后自加  这里++num=1 num=1
        console.log(0 || num++);        //1  ++num是先自加后运算  num++是先运算后自加  这里num++=1 num=2
        console.log(num);               //2

        var n = 0;
        console.log(123 || ++n);        //123  ++n是先自加后运算  这里没有进行++n运算因为在前面取到真值已经中断了
        console.log(123 || n++);        //123  ++n是先自加后运算  这里没有进行n++运算因为在前面取到真值已经中断了
        console.log(n);               //0

在这里插入图片描述
全部代码:

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>短路运算</title>
    <script>
        // 逻辑与
        console.log('逻辑与的逻辑中断');
        console.log(0 && 123);          //0
        console.log(123 && 0 && 456);   //0
        console.log('' && 123);         //''
        console.log(1 && 2 * 9 && 666);   //666
        var num = 0;
        console.log(0 && num++);        //0
        console.log(num);               //0
        console.log('-----------------------------------');
        console.log('逻辑或的逻辑中断');
        console.log(0 || 123);          //123
        console.log(123 || 0 || 456);   //123
        console.log('' || 123);         //123
        console.log(1 || 2 * 9 || 666);   //1
        var num = 0;
        console.log(0 || ++num);        //1  ++num是先自加后运算  num++是先运算后自加  这里++num=1 num=1
        console.log(0 || num++);        //1  ++num是先自加后运算  num++是先运算后自加  这里num++=1 num=2
        console.log(num);               //2

        var n = 0;
        console.log(123 || ++n);        //123  ++n是先自加后运算  这里没有进行++n运算因为在前面取到真值已经中断了
        console.log(123 || n++);        //123  ++n是先自加后运算  这里没有进行n++运算因为在前面取到真值已经中断了
        console.log(n);               //0



    </script>
</head>

<body>

</body>

</html>

在这里插入图片描述

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-02-28 15:20:07  更:2022-02-28 15:20:38 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/10 10:27:27-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码