JS的数据类型分为基本数据类型和引用数据类型
一、数据类型 – 数字类型(Number)
JavaScript 中的正数、负数、小数等 统一称为 数字类型
JS 是弱数据类型,变量到底属于那种类型,只有赋值之后,我们才能确认
Java是强数据类型 例如 int a = 3 必须是整数
- 算术运算符
主要包括加+、减-、乘*、除/、取余(求模)% - 算术运算符的优先级
JavaScript中 优先级越高越先被执行,优先级相同时以书从左向右执行。- 乘、除、取余优先级相同
- 加、减优先级相同
- 乘、除、取余优先级大于加、减
- 使用 () 可以提升优先级
- 总结: 先乘除后加减,有括号先算括号里面的
-
NAN(not a number)
NaN 代表一个计算错误。它是一个不正确的或者一个未定义的数学操作所得到的结果
NaN 是粘性的。任何对 NaN 的操作都会返回 NaN
二、数据类型 – 字符串类型(string)
通过单引号( '') 、双引号( "")或反引号( ` ) 包裹的数据都叫字符串,推荐使用单引号
注意
- 无论单引号或是双引号必须成对使用
- 单引号/双引号可以互相嵌套,但是不以自已嵌套自已(口诀:外双内单,或者外单内双)
- 必要时可以使用转义符 \,输出单引号或双引号
-
+运算符 可以实现字符串的拼接
口诀:数字相加,字符相连 -
模板字符串
语法:字符串用反引号``包含变量用${}包含
let name = prompt("请您输入姓名:")
let age = prompt("请您输入年龄:")
document.write(`大家好!我叫${name},今年${age}岁了`)
三、数据类型 – 布尔类型(boolean)
有两个固定的值 true 和 false,表示肯定的数据用 true(真),表示否定的数据用 false(假)
四、数据类型 – 未定义类型(undefined)
只有一个值 undefined
只声明变量,不赋值的情况下,变量的默认值为 undefined
如果检测变量是undefined就说明没有值传递过来
五、数据类型 – 空类型(null)
null 仅仅是一个代表“无”、“空”或“值未知”的特殊值
null 开发中的使用场景:把 null 作为尚未创建的对象(将来有个变量里面存放的是一个对象,但是对象还没创建好,可以先给个null)
-
null 和 undefined 区别:
- undefined 表示没有赋值
- null 表示赋值了,但是内容为空
六、检测数据类型
- 可以看控制台输出数字型和布尔型颜色为蓝色,字符串和undefined颜色为灰色
- 通过 typeof 关键字检测数据类型
typeof 运算符可以返回被检测的数据类型。它支持两种语法形式:- 作为运算符: typeof x (常用的写法)
- 函数形式: typeof(x)
换言之,有括号和没有括号,得到的结果是一样的,所以我们直接使用运算符的写法
七、类型转换
- 为什么需要类型转换?
JavaScript是弱数据类型: JavaScript也不知道变量到底属于那种数据类型,只有赋值了才清楚
使用表单、prompt 获取过来的数据默认是字符串类型的,此时就不能直接简单的进行加法运算
隐式转换
某些运算符被执行时,系统内部自动将数据类型进行转换,这种转换称为隐式转换。
- 规则:
+号两边只要有一个是字符串,都会把另外一个转成字符串
除了+以外的算术运算符 比如- * / 等都会把数据转成数字类型 - 缺点:
转换类型不明确,靠经验才能总结 - 小技巧:
+号作为正号解析可以转换成数字型
任何数据和字符串相加结果都是字符串
显式转换
转换为数字型
-
Number(数据)- 转成数字类型
- 如果字符串内容里有非数字,转换失败时结果为 NaN(Not a Number)即不是一个数字
- NaN也是number类型的数据,代表非数字
-
parseInt(数据)
只保留整数 -
parseFloat(数据)
可以保留小数(整数小数都有)
转换为字符串型
String(数据)变量.toString(进制)
