经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » JS/JS库/框架 » JavaScript » 查看文章
JS疑惑的数据类型及类型判断方法详解
来源:jb51  时间:2022/8/16 17:28:01  对本文有异议

前言

关于javascript这门语言的数据类型你了解多少呢?你有什么方法能够快速的判断数据类型呢?如果可以那如何实现类型转换呢?带着这三个问题开始我们今天的学习吧

数据类型

在javascript中数据类型我们一般分为基本数据类型(值类型) 和 引用数据类型(对象类型);

基本数据类型有:

  • number
  • String
  • boolean
  • Null
  • Undefined
  • BigInt
  • Symbol

引用数据类型有:

  • Object(对象)
  • Array(数组)
  • Function(函数)
  • Date等(内置对象)

类型判断

一、typeof方法

  1. typeof 123 // "number"
  2. typeof 'a' // "string"
  3. typeof true // "boolean"
  4. typeof undefined // "undefined"
  5. typeof Symbol() // "symbol"
  6. typeof 21n // "bigint"

通过以上这些例子我们可以总结出一个规律: typeof方法可以准确判断出除了Null之外的所有的基本数据类型(注:typeof null // "object" 是javascript这门语言的历史遗留问题,需要记忆),其他六种基本数据类型都能准确判断,所以我们可以用(typeof 变量 === “undefined”)来判断一个变量是否被声明;但是在判断引用类型时typeof智能判断出函数类型,其他的引用类型都返回'object'。 所以我们通常会使用typeof方法来判断基本数据类型。

二、Object.prototype.toString.call()方法

Object.prototype.toString.call()方法,它的返回值是"[ object , 类型]"(注:返回值前面是小写字母,后面是大写字母开头的类型)

  1. Object.prototype.toString.call(123) // "[object Number]"
  2. Object.prototype.toString.call('abc') // "[object String]"
  3. Object.prototype.toString.call(Symbol()) // "[object Symbol]"
  4. Object.prototype.toString.call(21n) // "[object BigInt]"
  5. Object.prototype.toString.call(null) // "[object Null]"
  6. Object.prototype.toString.call(undefined) // "[object Undefined]"
  7. Object.prototype.toString.call(true) // "[object Boolean]

由此可见Object.prototype.toString.call()方法可以准确判断所有的基本数据类型,那么对引用数据类型呢?

  1. Object.prototype.toString.call({a:1}) // "[object Object]"
  2. Object.prototype.toString.call([1,2]) // "[object Array]"
  3. Object.prototype.toString.call(new Date) // "[object Date]"
  4. Object.prototype.toString.call(function(){}) // "[object Function]"
  5. Object.prototype.toString.call(new Error()) // "[object Error]"
  6. Object.prototype.toString.call(/a/g) // "[object RegExp]"--正则表达式
  7. Object.prototype.toString.call(Math) // "[object Math]"
  8. Object.prototype.toString.call(JSON) // "[object JSON]"

所以Object.prototype.toString.call()方法可以识别出javascript这门语言中所有的数据类型(据我所知,上述例子中Math属性和正则严格意义上也不算数据类型,因为可以识别出,所以也放在例子里)。

小插曲

如何使用上述的两种方法优雅的封装一个方法,使得我们可以传入任意数据,直接返回它的数据类型(小写字母的字符串)?

方法一:

  1. function dataType(obj) {
  2. return Object.prototype.toString.call(obj).slice(8,-1)
  3. }

方法二:

  1. let dataType = {}
  2. ['Boolean', 'Number', 'String', 'Array', 'Function', 'Date', 'RegExp', 'Object',
  3. 'Error', 'Undefined', 'Null'].map((item, index) => {
  4. dataType["[object" + item + "]"] = item.toLowerCase();
  5. })
  6. function type(obj) {
  7. return typeof obj === 'object' || typeof obj === 'function'
  8. ? dataTypeObject.prototype.toString.call(obj)]
  9. || 'object' : typeof obj
  10. }

我们一起来解读一下方法二,首先我们先将数据类型的首字母都转化为小写字母,并在添加为我们创建的dataType对象的属性(toLowerCase() 方法将字符串转换为小写。)

当我们传入一个数据时,首先用typeof去判断是基本数据类型还是引用数据类型,因为typeof null // "object",所以我们的判定条件typeof obj === 'object' || typeof obj === 'function',就把特殊的null当做引用类型,使用Object.prototype.toString.call()方法也能识别出,实现我们想要的效果。

(在学习过程中我们尽可能多去复杂化问题,使得理解更加深刻,方法一实用性较大)

三、Array.isArray()

在数组身上有一种isArray方法可以判断是否为数组类型数据,返回值是布尔类型(true || false)(在其他语言中arr2 = [1, 'abc', true]严格意义上不算数组,但是在javascript中属于数组 )

四、obj instanceof Object

左边放你要判断的内容,右边放类型来进行JS类型判断,只能用来判断复杂数据类型,因为instanceof 是用于检测构造函数(右边)的 prototype 属性是否出现在某个实例对象(左边)的原型链上。

  1. [1,2] instanceof Array // true
  2. (function(){}) instanceof Function // true
  3. ({a:1}) instanceof Object // true
  4. (new Date) instanceof Date // true
  5. 实现原理:
  6. function instance_of(L,R){
  7. let O = R.prototype
  8. let L = L.__proto__
  9. while(L !== null){
  10. if(L === O) return true
  11. L = L.__proto__
  12. }
  13. return false
  14. }
  15. obj instanceof Object方法也可以判断内置对象。

结语

以上就是本期的所有内容,相信此时,判断javascript中的数据类型已经没有什么可以难倒你了,当然判断数据类型的方法不仅这些,但是以上的几种方法(应该)可以解决所有的数据类型判断的问题。

以上就是JS疑惑的数据类型及类型判断方法详解的详细内容,更多关于JS数据类型判断的资料请关注w3xue其它相关文章!

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号