当前位置: 首页 > news >正文

js判断数据类型的方法

简单数据类型用:typeof,

// 可以直接typeof空格接数据的方式,也可以typeof(数据)的方式使用
console.log(typeof "");            //string(检验字符串没问题)
console.log(typeof 1);             //number(检验数字没问题)
console.log(typeof true);          //boolean(检验布尔值没问题)
console.log(typeof undefined);     //undefined(检验undefined没问题)
console.log(typeof []);            //object(检验数组待定)
console.log(typeof {});            //object(检验数字没待定)
console.log(typeof null);          //object!!!(检验null没待定)
console.log(typeof function(){});  //function(检验函数没问题)
console.log(typeof Symbol());      //symbol(es6)(检验Symbol没问题)
console.log(typeof 666n);        //bigint(es11)(检验bigint没问题)
// 由此可见typeof检验结果在为对象,数组,null 时都是结果都是object,所以不一定完全准确

引用数据类型用:instanceof(可以跟typeof结合起来用就能判断所有的数据类型了)

// 写法:数据空格instanceof数值类型(大写开头)
console.log(9 instanceof Number);                    // false(判断基本数据类型无效)
console.log(true instanceof Boolean);                // false(判断基本数据类型无效)
console.log('libo' instanceof String);               // false(判断基本数据类型无效)
console.log([] instanceof Array);                    // true(数组不再是对象类型而是具体到数组类型)
console.log({} instanceof Object);                   // true(依旧是对象没问题)
console.log(null instanceof Object);                 //false (null也不再是对象)
console.log(function(){} instanceof Function);       // true(函数也没问题)
// 由此可见instanceof可以用来区别数组,对象,以及null三个类型

一步到位用:Object.prototype.toString.call()

// 最强绝招Object.prototype.toString.call()
// 这个方法几乎检验所有的数据类型,返回的结果是一个中括号型字符串,字符串后面部分即为数据类型
console.log(Object.prototype.toString.call(''))              // [object String]
console.log(Object.prototype.toString.call(1))               // [object Number]
console.log(Object.prototype.toString.call(true))            // [object Boolean]
console.log(Object.prototype.toString.call(Symbol()))         // [object Symbol]
console.log(Object.prototype.toString.call(666n))         		// [object BigInt]
console.log(Object.prototype.toString.call(undefined))       // [object Undefined]
console.log(Object.prototype.toString.call(null))            // [object Null]
console.log(Object.prototype.toString.call(NaN))            	// [object Number](NaN是个例外结果是个Number)
console.log(Object.prototype.toString.call(function(){}))  	// [object Function]
console.log(Object.prototype.toString.call(new Date()))      // [object Date]
console.log(Object.prototype.toString.call([]) )              // [object Array]
console.log(Object.prototype.toString.call(new RegExp()))    // [object RegExp]
console.log(Object.prototype.toString.call(new Error()))    	// [object Error]
console.log(Object.prototype.toString.call(document))        // [object HTMLDocument](甚至能识别是否为dom元素)
console.log(Object.prototype.toString.call(window))          // [object window] 

http://www.lryc.cn/news/171444.html

相关文章:

  • 达梦数据库随系统开机自动启动脚本
  • Python开发利器之VS Code
  • 【Axure视频教程】输入框控制滑动评分条
  • 【学习笔记】[AGC064C] Erase and Divide Game
  • 算法通关村-----数组中元素出现次数问题
  • Qt-键盘消息的传递-键盘消息的获取-C++
  • 数据结构与算法(五)--链表概念以及向链表添加元素
  • 计算机视觉与深度学习-图像分割-视觉识别任务02-目标检测-【北邮鲁鹏】
  • Flink——Flink检查点(checkpoint)、保存点(savepoint)的区别与联系
  • [篇五章五]-如何禁用 Windows Defender-我的创作纪念日
  • 什么情况下使用微服务?
  • 【Linux】Ubuntu美化主题【教程】
  • spring-boot2.x,使用EnableWebMvc注解导致的自定义HttpMessageConverters不可用
  • 2023-09-20 Android CheckBox 让文字显示在选择框的左边
  • 目标检测YOLO实战应用案例100讲-基于改进YOLOv5的口罩人脸检测
  • CentOS7 yum安装报错:“Could not resolve host: mirrorlist.centos.org; Unknown error“
  • 关于token续签
  • 淘宝分布式文件存储系统( 二 ) -TFS
  • Java中synchronized:特性、使用、锁机制与策略简析
  • 记一次clickhouse手动更改分片数异常
  • 深度学习论文: ISTDU-Net:Infrared Small-Target Detection U-Net及其PyTorch实现
  • 图像识别-YOLO V8安装部署-window-CPU-Pycharm
  • js禁用F1至F12、禁止缩放、取消选中并且取消右键操作、打印、拖拽、鼠标点击弹出自定义信息、禁用开发者工具js
  • Zabbix5.0_介绍_组成架构_以及和prometheus的对比_大数据环境下的监控_网络_软件_设备监控_Zabbix工作笔记
  • 百度SEO优化TDK介绍(分析下降原因并总结百度优化SEO策略)
  • 搭建自动化 Web 页面性能检测系统 —— 设计篇
  • 记一次 mysql 数据库定时备份
  • 淘宝分布式文件存储系统(一) -TFS
  • LLM各层参数详细分析(以LLaMA为例)
  • linux ansible(三)