JS高级_数据类型
数据类型
分类(2大类)
基本(值)类型
Number: 任意数值
string: 任意文本(在 JavaScript 中, string 这个词的首字母是小写的 s 。这是 JavaScript 语言的约定和规范。)
Boolean: true/false
undefined: undefined
null: null
对象(引用)(Object(它是构造函数))类型
Object: 任意对象
Array: 特别的对象类型(下标/内部数据有序)
Function: 一种特别的对象类型(可执行)
判断
- typeof:
返回数据类型的字符串表达- 可以区别: 数值, 字符串, 布尔值, undefined, function
- 不能区别: null与对象, 一般对象与数组(函数除外)1,因为不管用typeof判断对象中任意一种类型,返回的都是obj
-
instanceof(实例)
返回布尔值- 专门用来判断对象的具体类型(判断到底是函数还是数组): Object, Array与Function
-
===
- 可以判断: undefined和null
尽量不用==,因为==可以做数据转换,所以会判断不准确
- 可以判断: undefined和null
// typeof
var a
console.log(a, typeof a, a === undefined) // undefined 'undefined' true
console.log(a === typeof a) // false
// typeof: 返回的是数据类型的字符串表达形式
a = 3
console.log(typeof a === 'number')//true
a = 'atguigu'
console.log(typeof a === 'string')//true
a = true
console.log(typeof a === 'boolean')//true
// 不能区别: null与对象(函数除外)
a = null
b = { 1: 1, 2: 2, 3: 3 }
console.log(a === null) // true
console.log(typeof a) // 'object'
console.log(typeof [1, 2, 3]) // 'object'
console.log(typeof { 1: 1, 2: 2, 3: 3 }) // 'object'
console.log(typeof function () { }) // 'function'[1^]
//instanceof
var b1 = {
b2: [2, 'abc', console.log],
b3: function () {
console.log('b3()')
}
}
console.log(b1 instanceof Object, typeof b1) // true 'object'
console.log(b1.b2 instanceof Array, typeof b1.b2) // true 'object'
console.log(b1.b3 instanceof Function, typeof b1.b3) // true 'function'
console.log(typeof b1.b2[2]) // 'function'
console.log('--------------------------------%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%')
console.log(b1.b2[2]('abc')) // 'abc' undefined.后面这个undefined是因为括号里面那个函数(b1.b2[2]('abc'))没有返回值。
在 JavaScript 中,
typeof
运算符用于获取给定变量的数据类型
函数在 JavaScript 中确实是一种特殊的对象,但typeof
运算符会返回函数的类型为'function'
,而不是'object'
。是因为在 JavaScript 中,函数也被视为一种特殊的对象类型,但它有自己的行为和特性,因此被归类为'function'
类型。 ↩︎
原文地址:https://blog.csdn.net/jkjkikik/article/details/136691116
免责声明:本站文章内容转载自网络资源,如本站内容侵犯了原著者的合法权益,可联系本站删除。更多内容请关注自学内容网(zxcms.com)!