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

邹平网站建设公司报价湖州seo排名

邹平网站建设公司报价,湖州seo排名,成都专业网站建设公司排名,如何制作自己的作品集检测数据类型的4种方法typeofinstanceofconstructor{}.toString.call() 检测数据类型的4种方法 typeof 定义 用来检测数据类型的运算符 返回一个字符串,表示操作值的数据类型(7种) number,string,boolean,object,u…
  • 检测数据类型的4种方法
  • typeof
  • instanceof
  • constructor
  • {}.toString.call()

检测数据类型的4种方法

typeof

定义

用来检测数据类型的运算符
返回一个字符串,表示操作值的数据类型(7种)
number,string,boolean,object,undefined,symbol,function
使用方法1:typeof(value)
使用方法2:typeof value

typeof(null)

注意: typeof(null) === 'object'
(这是浏览器遗留的BUG:所有的值都以二进制编码存储,浏览器中把前三位000的当作对象,而null的二进制前三位是000,所以识别为对象,但他不是对象,而是空指针对象,是基本类型值)

typeof(undefined)

typeof undefined === ‘undefined’
注意:typeof 未声明的变量,返回 'undefined'

typeof a;//'undefined'
typeof typeof a;//'string'

instanceof

定义:用来检测某个实例是否属于这个类,返回布尔值
==》 当前类的原型只要出现在实例的原型链上就返回 true
使用方法:实例 instanceof 类
优点:弥补 typeof 无法细分对象类型的特点
局限性:

  1. 只能检测对象数据类型
'a' instanceod Object;//false
// 例如
ImageryProvider instanceof Cesium.ImageryProvider
  1. 构造函数创建的基本类型可以检测
var a = new String('a')
a instanceof Object
  1. 万物皆对象,数组对象正则都是 Object的实例

constructor

定义:判断当前的实例的 constructor 的属性值,返回函数
==》 利用他的实例的构造函数检测
==》 一般实例.constructor === 类.prototype.constructor
使用方法:实例.constructor === 类
优点:能够检测所有的数据类型,包括自定义类

function Person (){...}
new Person().constructor; //ƒ Person (){}

缺点:JS中的 constructor 是不被保护的,可以重定向

Array.constructor;// f Array () {}
Array.constructor = 1;// 1

{}.toString.call() 推荐

定义:对象原型上的toString方法,能返回当前实例所属类的信息 ==》返回字符串
使用方法:Object.prototype.toString.call(被检测的实例)
优点:基本能基础所有的数据类型

console.log({}.toString.call(1));// '[object Number]'
console.log({}.toString.call('a'));// '[object String]'
console.log({}.toString.call(true));// '[object Boolean]'
console.log({}.toString.call(Symbol.for('a')));// '[object Symbol]'
console.log({}.toString.call(undefined));// '[object Undefined]'
console.log({}.toString.call(null));// '[object Null]'
console.log({}.toString.call({}));// '[object Object]'
console.log({}.toString.call([]));// '[object Array]'
console.log({}.toString.call(/a/g));// '[object RegExp]'

局限性:自定义类都返回 '[object Object]'

function Test(a){this.a = 1}
let test = new Test(1)
console.log({}.toString.call(test))//'[object Object]'
http://www.mmbaike.com/news/89933.html

相关文章:

  • 做新闻微网站有哪些方面电商培训学校
  • wordpress网站存放在网络营销公司名称
  • 网站正在建设中的图片素材seo优化查询
  • 网站怎样排版无锡百度推广开户
  • 淘客网站开发教程网站后台管理系统
  • 上海做网站的价格济南seo优化
  • 网站建设 艺麟盛世谷歌排名推广公司
  • 免费凡客建站官网传智播客培训机构官网
  • 网站建设接外包流程图一个域名大概能卖多少钱
  • 做个网站需要什么步骤河南省网站
  • 网站的demo怎么做网络新闻发布平台
  • 中英语网站制作方法怎样制作一个自己的网站
  • 网站后台数据库设计卢松松外链工具
  • 目前做汽配的网站有哪些常州seo建站
  • 专门做投标书的网站网站优化公司怎么选
  • 北京优秀的网站建设公司网络推广的基本渠道
  • 做动物网站的原因是济南网站建设公司
  • 创建网站制作首页快速排名上
  • 网站建设无形资产的账务处理网站关键词百度自然排名优化
  • 合肥网站建设哪家好珠海百度关键字优化
  • 极速网站建设网络项目平台
  • 做网站推广维护需要学些什么惠州seo全网营销
  • 网站怎么做下载优化分析
  • 建设网站论坛网站平台都有哪些
  • 潍坊网站排名在线网站建设平台
  • 怎么看网站后台网页尺寸软文台
  • seo优化多少钱免费网站seo优化
  • 模板网站区别微商怎么找客源人脉
  • 网站建设公司介绍深圳网络推广
  • python网站开发快吗网页广告