JS基础 —— 数据类型
JS数据类型分为简单数据类型(基本数据类型)和复杂数据类型(引用数据类型)。
基本数据类型:Undefined、Null、Boolean、Number、String、Symbol。
引用数据类型:Object。
可以通过typeof操作符判断以上7种数据类型,语法:typeof 变量,返回值如下:
- "undefined" —— 如果这个值未定义;事实上,如果这个变量未声明,返回值也是undefined
- "boolean" —— 如果这个值是布尔值
- "string" —— 如果这个值是字符串
- "number" —— 如果这个值是数值
- "object" —— 如果这个值是对象或null
- "symbol" —— 如果这个值是Symbol函数生成的
- "function" —— 如果这个值是函数
数据类型
Undefined类型
- 只有一个值:undefined
- 声明变量后未经初始化,则默认值是undefined;所以没必要将一个变量显性地设置为undefined
Null类型
- 只有一个值:null
- 空对象指针
- undefined派生自null,所以它们的相等性测试 undefined == null 返回 true
- 与undefined不同的是,只要意在保存对象的变量还没有真正保存对象,就应该明确地让变量初始化为null
Boolean类型
只有两个值:true 和 false
其它类型值转换为Boolean值,调用转型函数Boolean()
数据类型 转换为true值 转换为false值 Boolean true false String 非空字符串 空字符串("") Number 非0数字值 0和NaN Object 任何对象 null Undefined 无 undefined
Number类型
- 字面量
- 整数
- 十进制:ddd,d:0~9
- 八进制: 0ddd,d:0~7。严格模式下无效,会导致支持严格模式地JS引擎抛出错误
- 十六进制:0xddd,d:09及AF(小写也可以)
- 浮点数值
- 合法写法
- '1.1'
- '0.1'
- '.1' --> 0.1
- '1.' --> 整数 1
- '1.0' --> 整数 1
- 极大极小值,用e表示
- 3.125e7 --> 31250000
- 3e-7 --> 0.0000003
- 最大精度17位
- 0.1 + 0.2 != 0.3
- 合法写法
- 整数
- 数值范围
- Number.MIN_VALUE
- Number.MAX_VALUE
- 超范围显示Infinity和-Infinity --> Number.POSITIVE_INFINITY和Number.NEGATIVE_INFINITY
- 函数isFinite():参数在极小和极大之间返回true,否则false
- NaN
- Not a Number
- NaN == NaN 返回 false
- 函数isNaN():参数先被转换成Number类型,转换后的结果是NaN返回true,否则false;参数是对象,会先调用valueOf()方法,如果返回值能转换为数值,则进行测试,否则再调用toString()方法,进行测试
- 数值转换
Number()
数据类型 Number()转换后结果 Boolean 1和0 Number 无变化 Null 0 Undefined 0 String 只包含数字(包括前面带正号或负号的情况)--> 十进制数值,如"-123" --> 123,"077" --> 77(不会被认为是八进制);有效浮点格式 --> 浮点值;十六进制(0x) --> 十进制数值;其它 --> NaN Object valueOf()→若是NaN(比如Object对象)→toString()→再按以上规则 parseInt()
- 字符串从前往后取数字(符合整数格式),碰到非数字停止
- 第二个参数指定进制,如8,10,16
parseFloat()
- 同上(符合浮点格式)
注:valueOf()
- 对象原型方法:返回对象的原始值。
- 查看对象的原始值办法


- 字面量
String类型
- 字符:16位Unicode
- "" 或 ''
- 转义字符:\
- 其它类型转换为String类型
- toString()
- Boolean、Number、String、Object都有toString()方法
- Null、Undefined没有toString()方法
- Object.prototype.toString.call():可以查看数据类型
- 转型函数String()
- 有toString()方法的调用toString()
- null --> "null"
- undefined --> "undefined"
- toString()
- 字符串拼接
- 新开辟空间,拼接字符串,删除原字符串
Symbol类型
- ES6引入的一种新的原始数据类型Symbol,表示独一无二的值
- 通过Symbol()函数生成,可传入参数用作描述
- 应用:保证属性名独一无二,防止属性名冲突


- Symbol()生成的属性名不能被for...in,for...of,Object.keys()、Object.getOwnPropertyNames()、JSON.stringify()访问到,但可以用Object.getOwnPropertySymbols(obj)获取
- Reflect.ownKeys(obj)也可以返回所有类型的键名,包括常规键名和Symbol键名
Object类型
- Object 就是一组数据和功能的集合
- 所有对象的基础,如Function、Array、Date
- Object每个实例都有:constructor、hasOwnProperty(propertyName)、isPropertyOf(object)、propertyIsEnumerable(propertyName)、toLocaleString()、toString()、valueOf()
检测数据类型
- 操作符 typeof
- 能检测出的类型:Undefined、Null、Boolean、Number、String、Object、Symbol和函数
- 操作符 instanceOf
- 区分具体对象类型,如 [1,2,3] instanceof Array --> true ; 1 instanceof Number --> true
- null、undefined不行
- 方法 constructor()

- 同instanceof
- 方法 toString()
- 能检测出的类型:所有
参考
- JavaScript高级程序设计(v3)Nicholas C.Zakas著 李松峰 曹力译
- ES6标准入门(v3)阮一峰著
- 互联网
JS基础 —— 数据类型的更多相关文章
- js 基础数据类型和引用类型 ,深浅拷贝问题,以及内存分配问题
js 深浅拷贝问题 浅拷贝一般指的是基本类型的复制 深拷贝一般指引用类型的拷贝,把引用类型的值也拷贝出来 举例 h5的sessionStorage只能存放字符串,所以要存储json时就要把json使用 ...
- JS基础-数据类型-运算符和表达式-变量和常量
1.js的基础语法2.js调试 1.F12调出控制台,查看提示错误及其位置. 2.出错时只影响当前代码块,不会影响其他代码块,后续代码块继续执行.3.语法规范 1.js语句:可执行的最小单元 必须以 ...
- js基础--数据类型
1,数据类型 Number:包括小数与整数,负数,NaN ,Infinity无限大String字符串:‘abc’Boolean布尔值:true or falsenull 空undefined 未定义 ...
- JS基础-数据类型判断typeof、instanceof、Object.prototype.toString
typeof用在基本数据类型和函数时,返回其对应类型的描述,对于引用类型都返回为object. instanceof无法判断基本数据类型,对于引用类型数据,返回其其对应类型. Object.proto ...
- 前端面试题目汇总摘录(JS 基础篇)
JS 基础 JavaScript 的 typeof 返回那些数据类型 object number function boolean undefined string typeof null; // o ...
- js基础--javaScript数据类型你都弄明白了吗?绝对干货
欢迎访问我的个人博客:http://www.xiaolongwu.cn 数据类型的分类 JavaScript的数据类型分为两大类,基本数据类型和复杂数据类型. 基本数据类型:Null.Undefine ...
- JS基础入门篇(六)— 数据类型
1.数据类型 数据类型:我感觉就是对数据的种类进行分类.就好比把人分为儿童,青少年,中年,老年一样. 基础数据类型: Number(数字),String(字符串),Null(空),Undefined( ...
- Python--前端基础之JavaScript(JS的引入方式,JS的变量、常量和标识符,JS的数据类型,运算符,流程控制,JavaScript的对象)
JavaScript介绍 JavaScript是运行在浏览器端的脚步语言,JavaScript主要解决的是前端与用户交互的问题,包括使用交互与数据交互. JavaScript是浏览器解释执行的,前端脚 ...
- JS基础——脚本位置、数据类型、函数作用域
(一)脚本位置 JavaScript是嵌套到浏览器里的脚本语言:可放在3个位置: 1.写在头部(head里) <head> <meta charset="UTF-8& ...
随机推荐
- NLP中的预训练语言模型(四)—— 小型化bert(DistillBert, ALBERT, TINYBERT)
bert之类的预训练模型在NLP各项任务上取得的效果是显著的,但是因为bert的模型参数多,推断速度慢等原因,导致bert在工业界上的应用很难普及,针对预训练模型做模型压缩是促进其在工业界应用的关键, ...
- c# 第15节 StringBuilder
本节内容: 1:StringBuilder 2:内容总结 1:StringBuilder 实例: 2:内容总结 项目:
- chrony软件
chrony简介 Chrony是一个开源的自由软件,它能保持系统时钟与时钟服务器(NTP)同步,让时间保持精确. 它由两个程序组成:chronyd和chronyc. chronyd是一个后台运行的守护 ...
- zz2017-2018年AI技术前沿进展与趋势
2017年AI技术前沿进展与趋势 人工智能最近三年发展得如火如荼,学术界.工业界.投资界各方一起发力,硬件.算法与数据共同发展,不仅仅是大型互联网公司,包括大量创业公司以及传统行业的公司都开始涉足人工 ...
- pointnet++之scannet/train.py
1.作者可能把scannet数据集分成了训练集和测试集并处理成了.pickle文件. 2.在代码运行过程中,作者从.pickle文件中读出训练集1201个场景的x.y.z坐标和测试集312个场景的x. ...
- SQL基础知识整理
建议:关键字和函数名全部大写:数据库名称.表名称.字段名称全部小写:分号结尾.但是大小写语句不区分,本人讨厌大写(英语菜,不能一眼看出内容),所以全部小写.[]看情况可有可无,{}花括号的内容必须要有 ...
- Taro/微信小程序解析XML
npm i xmldom PS: https://www.npmjs.com/package/xmldom https://blog.csdn.net/caojie1008/article/detai ...
- 2019 SDN上机第3次作业
1. 利用Mininet仿真平台构建如下图所示的网络拓扑,配置主机h1和h2的IP地址(h1:10.0.0.1,h2:10.0.0.2),测试两台主机之间的网络连通性 创建拓扑 配置主机h1和h2的I ...
- mark-杭州互联网公司分布-位置信息
项目内容: 在智联招聘上爬取杭州市互联网公司的位置信息,属于哪个区: 如果公司信息内不含区信息,则通过百度地图接口获取所属区信息 scrapy+pycharm
- ESP8266 LUA脚本语言开发: 准备工作-LUA开发是怎么来的
前言 当前8266有各种开发 1.在官方已经封装好的C库上开发(SDK开发) 2.官方在SDK的基础上封装的AT指令程序(AT指令开发) 3.在SDK的基础上嵌入脚本语言(Lua,Python等开发方 ...