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

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

写在前头

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


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


思维导图

微信截图_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--语句执行之后在执行{}。


目录
相关文章
|
10天前
|
C++ 容器 存储
【C++语言】想学STL,先细细拿捏string类,万字详解string类 (内附精美思维导图)
【C++语言】想学STL,先细细拿捏string类,万字详解string类 (内附精美思维导图)
|
7月前
|
存储 编译器 程序员
c语言(从入门到放弃?NONONO,LET我们一步一步刨析,会发现其中蕴含的乐趣)
c语言(从入门到放弃?NONONO,LET我们一步一步刨析,会发现其中蕴含的乐趣)
51 0
|
存储 编译器 程序员
0基础C保姆自学 第二节——初步认识C语言的全部知识框架
在栈区的变量用完之后,系统会自动收回,不需要程序员手动释放,但在堆区则恰恰相反:我们需要用free函数来将我们创建的动态空间释放。否则将会造成内存泄漏。
183 0
0基础C保姆自学 第二节——初步认识C语言的全部知识框架
|
存储 人工智能 编译器
0基础C语言保姆教学——第五节 数组
在C99之前,这种写法是不允许的,而在C99之后,这种写法是允许的。而我们vs编译器的编译环境并不能很好的支持C99的语法,如果我们在gcc编译器或者其他对新语法更加支持的编译器下,这种写法是可以的。
119 0
0基础C语言保姆教学——第五节 数组
|
前端开发 JavaScript
带你读书之“红宝书”:第三章 语法基础(中)之 数据类型前部分
带你读书之“红宝书”:第三章 语法基础(中)之 数据类型前部分
68 0
带你读书之“红宝书”:第三章 语法基础(中)之 数据类型前部分
|
JavaScript 前端开发 Python
带你读书之“红宝书”:第三章 语法基础(上)
带你读书之“红宝书”:第三章 语法基础(上)
62 0
带你读书之“红宝书”:第三章 语法基础(上)
|
前端开发 C语言
带你读书之“红宝书”:第三章 语法基础(中)之 3.5操作符①
带你读书之“红宝书”:第三章 语法基础(中)之 3.5操作符①
56 0
带你读书之“红宝书”:第三章 语法基础(中)之 3.5操作符①
|
存储 前端开发 JavaScript
带你读书之“红宝书”:第三章 语法基础(中)之 3.5操作符②
带你读书之“红宝书”:第三章 语法基础(中)之 3.5操作符②
76 0
带你读书之“红宝书”:第三章 语法基础(中)之 3.5操作符②
|
前端开发 索引
带你读书之“红宝书”:第五章 基本引用类型⑧
带你读书之“红宝书”:第五章 基本引用类型⑧
55 0
带你读书之“红宝书”:第五章 基本引用类型⑧
|
JavaScript 前端开发
带你读书之“红宝书”:第五章 基本引用类型⑨
带你读书之“红宝书”:第五章 基本引用类型⑨
57 0
带你读书之“红宝书”:第五章 基本引用类型⑨