带你读书之“红宝书”:第三章 语法基础(中)之 数据类型中部分

简介: 带你读书之“红宝书”:第三章 语法基础(中)之 数据类型中部分

写在前头

大多数小伙伴看技术书籍都会用“啃”来描述读书的直观感受,当然我也是一个前端小白,白的透明那种,但是我在读技术书籍感觉到“啃”的时候,我希望把我啃红宝书第四版的过程的想法,总结带给大家,以供后来者能够更快上手。


注: 本文由于作者水平原因,如有错误之处,恳请大家指正,另外随着学习的深入,体会的加深,我会不断回来更新,修改这类文章。


思维导图

微信截图_20221111181407.png


脉络

这小节就是介绍了3.4数据类型 中的null数据类型,Boolean类型。


3.4数据类型

微信截图_20221111181416.png


3.4.3.Null类型

微信截图_20221111181424.png


  1. 只有一个值

null代表空对象指针,null数据类型只有一个值null。


  1. typeof返回值,原因

原因:nullnull代表空对象指针

对null使用typeof 会返回object。

const name = null;
    console.log(typeof name); // 输出object
复制代码


3.使用null做初始化对象值

上篇文章写到undefined是为了区分已声明未定义和空对象指针的区别而衍生出来的。

作用

那么null就起到初始化对象值的作用,

什么是初始化对象,就是当定义一个变量要保存一个对象值的时候,但是又不确定这个变量具体保存哪个一个对象值,于是使用null先“占个位置”表示这个变量是将要要保存对象值的。

let name = null;
    console.log(typeof name); // 输出object
复制代码


  1. null与undefined

由来

说第三遍了,哈哈哈,还是用原文的话说一次吧。undefined 值是由 null 值派生而来的。

比较

undefined和null都是假值,都会转换成为布尔值false,因此2者可以相等。

if (undefined == null) {
    console.log(true); // true
  }
复制代码


用途

算是复习了,undefined用于表示声明未赋值的数据类型。null表示空对象指针。


  1. 检测null假值

由于null也是假值那么同样可以使用if,trycatch来判断假值来判断null

// trycatch
if (typeof age == 'undefined') {
    try {
        // 未初始化
        console.log(age);
    } catch (error) {
    console.error('age is undeclared.');
        }
}
复制代码


null是一个假值,什么是假值,也就是说通过数据类型转换之后,会转换为false。既然可以转换为布尔值false,那么我们自然就可以通过条件判断语句该判断他是否为一个假值,进而来判断他是否为null。


3.4.4Boolean类型

微信截图_20221111181435.png


  1. 两个布尔值

世界上没有绝对的正义和邪恶,但一定会有确定的布尔值,那就是true,false。

复习 :true,false是区分大小写的,只有一种固定写法。他们不是关键字,也不是标识符。属于字面量。


  1. 数值

可能有些人有c语言基础,知道条件语句中的1是真值,0是假值。但是这里其实是转换为布尔值了。并不代表true等于1,false等于0


  1. 大小写

布尔值只有唯一写法,其他写法是有效的标识符,不是布尔值。


  1. 和布尔值之间的转换规则

书中给了一个表,大部分就是“空”,“零”是假值false。其他是真值true。


  1. Boolean()转型函数

所有其他 ECMAScript 类型的值都有相应布尔值的等价形式,也就是说都可以转换成为对应的布尔值。那就得使用对应的转型函数了。


使用Boolean()将要转换的变量放在括号里面即可。

let age = 1;
const ageAsBoolean = Boolean(age); 
console.log(ageAsBoolean); // ture 
复制代码

复习 这里的ageAsBoolean 使用了驼峰命名法。


  1. 隐式布尔转换

也就是说其他的数据类型会“悄悄的去转换为布尔值”。比如if,while,for语句等等在将某一个数据类型作为判断条件时。

let i = 5;
while(i--) {
    console.log(i); //  4 3 2 1 0
}
复制代码


注意这里不会输出5 ,因为在将i暂时转换为布尔值之后是true。循环会进行{}里面的。但是是在i--语句执行之后在执行{}。


目录
相关文章
|
7月前
|
编解码 算法 数据可视化
【C 言专栏】运用 C 语言进行图形编程
【5月更文挑战第3天】本文探讨了C语言在图形编程中的应用,介绍了基础概念和常用图形库如OpenGL和SDL。通过初始化环境、绘制图形、处理用户输入及更新显示等步骤,阐述了图形编程过程。同时,文章提到了性能优化、兼容性处理和复杂图形绘制的挑战,以及通过实际游戏案例分析应用。随着技术发展,C语言图形编程在跨平台和移动设备上的前景广阔,鼓励读者深入学习和创新。
218 3
【C 言专栏】运用 C 语言进行图形编程
|
7月前
|
缓存 安全 编译器
【C 言专栏】C 语言函数的高效编程技巧
【5月更文挑战第1天】本文探讨了C语言中函数的高效编程技巧,包括函数的定义与作用(如代码复用和提高可读性)、设计原则(单一职责和接口简洁)、参数传递方式(值传递、指针传递和引用传递)、返回值管理、调用约定、嵌套与递归调用,以及函数优化技巧和常见错误避免。掌握这些技巧能提升C语言代码的质量和效率。
80 0
【C 言专栏】C 语言函数的高效编程技巧
|
前端开发 JavaScript
带你读书之“红宝书”:第三章 语法基础(中)之 数据类型前部分
带你读书之“红宝书”:第三章 语法基础(中)之 数据类型前部分
88 0
带你读书之“红宝书”:第三章 语法基础(中)之 数据类型前部分
|
JavaScript 前端开发 Python
带你读书之“红宝书”:第三章 语法基础(上)
带你读书之“红宝书”:第三章 语法基础(上)
87 0
带你读书之“红宝书”:第三章 语法基础(上)
|
前端开发 C语言
带你读书之“红宝书”:第三章 语法基础(中)之 3.5操作符①
带你读书之“红宝书”:第三章 语法基础(中)之 3.5操作符①
74 0
带你读书之“红宝书”:第三章 语法基础(中)之 3.5操作符①
|
存储 前端开发 JavaScript
带你读书之“红宝书”:第三章 语法基础(中)之 3.5操作符②
带你读书之“红宝书”:第三章 语法基础(中)之 3.5操作符②
101 0
带你读书之“红宝书”:第三章 语法基础(中)之 3.5操作符②
|
前端开发
带你读书之“红宝书”:第三章 语法基础(中)之 3.5操作符③
带你读书之“红宝书”:第三章 语法基础(中)之 3.5操作符③
77 0
带你读书之“红宝书”:第三章 语法基础(中)之 3.5操作符③
|
前端开发 JavaScript C语言
带你读书之“红宝书”:第三章 语法基础(中)之 3.5操作符④
带你读书之“红宝书”:第三章 语法基础(中)之 3.5操作符④
97 0
带你读书之“红宝书”:第三章 语法基础(中)之 3.5操作符④
|
前端开发 C语言
带你读书之“红宝书”:第三章 语法基础(中)之 3.6. 流控制语句②,3.7. 函数简介
带你读书之“红宝书”:第三章 语法基础(中)之 3.6. 流控制语句②,3.7. 函数简介
71 0
带你读书之“红宝书”:第三章 语法基础(中)之 3.6. 流控制语句②,3.7. 函数简介
|
前端开发
带你读书之“红宝书”:第三章 语法基础(上)之 关键词后续
带你读书之“红宝书”:第三章 语法基础(上)之 关键词后续
102 0
带你读书之“红宝书”:第三章 语法基础(上)之 关键词后续