第一百零七篇:基本数据类型(undefined,null,boolean类型)
好家伙,
本篇内容为《JS高级程序设计》第三章学习笔记
1.数据类型
ECMAScript有6种简单数据类型(称为原始类型):
Undefined, Null, Boolean, Number, String和Symbol。
Symbol (符号)是ECMAScript6新增的。还有一种复杂数据类型叫Object(对象)。
Object是一种无序名值对的集合。因为在ECMAScript中不能定义自己的数据类型,所有值都可以用上述7种数据类型之一来表示。
只有7种数据类型似乎不足以表示全部数据。但ECMAScript的数据类型很灵活,一种数据类型可以当作多种数据类型来使用。
1.1.type操作符
因为ECMAScript的类型系统是松散的,所以需要一种手段来确定任意变量的数据类型。
typeof操作符就是为此而生的。对一个值使用typeof操作符会返回下列字符串之一:
let a;
let b =true;
let c ="panghu";
let d = 20;
let e =new Object();
let f =function(){};
let g =Symbol("panghu"); console.log(typeof a);
console.log(typeof b);
console.log(typeof c);
console.log(typeof d);
console.log(typeof e);
console.log(typeof f);
console.log(typeof g);
生动形象:

当然,会有特殊情况:
typeof null 返回的是"object"
特殊值null被认为是一个对空对象的引用
let h =null;
console.log(typeof h);

2.undefined类型
undefined类型只有一个值,正是undefined,(我自成一类)
当声明了变量却没有初始化时,变量自动被赋予undefined值
2.1.显式赋值undefined

正常人应该能看出来这是一个完全没必要的操作
一般来说,永远不用显示的给某个变量设置undefined值.字面值undefined主要用于比较.
增加这个特殊值的目的就是为了正式明确空对象指针(null)和未初始化变量的区别
举个例子,
let panghu;
console.log(panghu);
console.log(kunkun);

有声明,无初始化,报undefined
无声明,报错
2.2.undefined是假值
undefined是假值
3.null类型
null类型只有一个值,即null,逻辑来说,null值表示一个空对象指针,
let h =null;
console.log(typeof h);
3.1.null值检测
在定义将来要保存对象值的变量时,建议使用null来初始化,不要使用其他值。
这样,只要检查这个变量的值是不是null就可以知道这个变量是否在后来被重新赋予了一个对象的引用,
比如:
if(panghu! =null){
//好了,我不为空了,我可能已经装了一个对象了,你不要乱动我
}
3.2.与undefined表面相等
console.log(null==undefined)

但与undefined不同的是,
当我们需要在变量中保存对象的时候,我们可以先用null来填充该变量
(确保该变量不会被塞入一些奇怪的东西)
3.3.null同样也是假值
4.boolean类型
boolean类型是ECMAScript中使用最频繁的类型之一,有两个字面值true和false.
这两个布尔值不同与数值,true不等于1,false不等于0;(true和false分大小写)
4.1.布尔值转型函数
let panghu = "panghu";
console.log(Boolean(panghu));

4.2.布尔值转换规则

(书里的原图)
第一百零七篇:基本数据类型(undefined,null,boolean类型)的更多相关文章
- “全栈2019”Java第一百零七章:匿名内部类与构造方法注意事项
难度 初级 学习时间 10分钟 适合人群 零基础 开发语言 Java 开发环境 JDK v11 IntelliJ IDEA v2018.3 文章原文链接 "全栈2019"Java第 ...
- 第一百零七节,JavaScript基本包装类型,数据类型的方法
JavaScript基本包装类型,数据类型的方法 学习要点: 1.基本包装类型概述 2.Boolean类型 3.Number类型 4.String类型 为了便于操作基本类型值,ECMAScript提供 ...
- python第一百零七天-- Django 基础 2
1.Django请求的生命周期 路由系统 -> 试图函数(获取模板+数据=>渲染) -> 字符串返回给用户 2.路由系统 /index/ -> 函数或类.as_view() / ...
- 第一百零六篇:变量的不同声明(var,let和const的不同)
好家伙,JS基础接着学, 本篇内容为<JS高级程序设计>第三章学习笔记 1.变量 ECMAScript 变量是松散类型的,意思是变量可以用于保存任何类型的数据. (确实松散,不像C或C++ ...
- hiho一下 第一百零七周 Give My Text Back(微软笔试题)
题目1 : Give My Text Back 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 To prepare for the English exam Littl ...
- 【leetcode 简单】 第一百零七题 回旋镖的数量
给定平面上 n 对不同的点,“回旋镖” 是由点表示的元组 (i, j, k) ,其中 i 和 j 之间的距离和 i 和 k 之间的距离相等(需要考虑元组的顺序). 找到所有回旋镖的数量.你可以假设 n ...
- “全栈2019”Java第一百零六章:匿名内部类与抽象类接口注意事项
难度 初级 学习时间 10分钟 适合人群 零基础 开发语言 Java 开发环境 JDK v11 IntelliJ IDEA v2018.3 文章原文链接 "全栈2019"Java第 ...
- “全栈2019”Java第一百零九章:匿名内部类实现唯一抽象类或接口
难度 初级 学习时间 10分钟 适合人群 零基础 开发语言 Java 开发环境 JDK v11 IntelliJ IDEA v2018.3 文章原文链接 "全栈2019"Java第 ...
- “全栈2019”Java第一百零五章:匿名内部类覆盖作用域成员详解
难度 初级 学习时间 10分钟 适合人群 零基础 开发语言 Java 开发环境 JDK v11 IntelliJ IDEA v2018.3 文章原文链接 "全栈2019"Java第 ...
随机推荐
- 避免jquery多次监听事件
jQuery.event.dispatch 事件分发监听源码简单理解是将绑定的事件放入队列后进行监听,如果对一个事件多次绑定(on或者bind),事件会重复添加到队列等待jq监听,这样会导致很大资源消 ...
- CodeForces - 1629C
Problem - 1629C - Codeforces 题意: 一个序列,每次可以从开头选择一个长度为K的序列,然后得到这个序列的MEX(最小的未出现的数),问最后可以求得的字典大小最大的序列是多少 ...
- 第三十二篇:vue的响应式原理
好家伙 什么是响应式?比较官方的回答: Vue.js 的核心包括一套"响应式系统". "响应式",是指当数据改变后,Vue 会通知到使用该数据的代码. 例如,视 ...
- KingbaseES 查询计划剖析
概述:了解KingbaseES查询计划对于开发人员和数据库管理员来说都是一项关键技能.这可能是优化SQL查询的第一件事,也是验证优化的SQL查询是否确实实现期望结果的方式. 1.KingbaseES数 ...
- NODE 基于express 框架和mongoDB的cookie和session认证 和图片的上传和删除
源码地址 https://gitee.com/zyqwasd/mongdbSession 本项目的mongodb是本地的mongodb 开启方法可以百度一下 端口是默认的27017 页面效果 1. 注 ...
- 10.Ceph 基础篇 - RGW 高可用
文章转载自:https://mp.weixin.qq.com/s?__biz=MzI1MDgwNzQ1MQ==&mid=2247485316&idx=1&sn=d3a6be41 ...
- Query String Query和Sumple Query String
- CentOS7配置nodejs环境
# 安装 wget https://nodejs.org/dist/v12.18.3/node-v12.18.3-linux-x64.tar.xz tar xf node-v12.18.3-linux ...
- Fluentd直接传输日志给kafka
官方文档地址:https://docs.fluentd.org/output/kafka td-agent版本自带包含out_kafka2插件,不用再安装了,可以直接使用. 若是使用的是Fluentd ...
- Node.js(一)基本node.js读取删除
npm init -y(初始化项目) npm uninstall (xxx模块名称)=>(移除模块) var text2=require("./text2"); //解构 c ...