JS中操作符typeof与instanceof的使用区别在哪
Admin 2022-06-27 群英技术资讯 1043 次浏览
这篇文章给大家介绍了“JS中操作符typeof与instanceof的使用区别在哪”的相关知识,讲解详细,步骤过程清晰,有一定的借鉴学习价值,因此分享给大家做个参考,感兴趣的朋友接下来一起跟随小编看看吧。typeof 和 instanceof 的知识点以及在开发中的使用建议,同时在面试过程中也经常会遇到这样的问题。typeof 操作符,确定任意变量的数据类型,确切说,它是判断一个变量是否为字符串、数值、布尔值或 undefined 的最好方式。其返回值为字符串类型,其使用方法如下:typeof 是一个操作符,不是一个函数,但是使用可以将变量作为参数传入:
a、typeof operand
b、typeof (operand)
(1)返回值为字符串类型,其中:
| 返回值 |
含义值 |
| "undefined" |
未定义 |
| "boolean" |
布尔值 |
| "string" |
字符串 |
| "number" |
数值 |
| "object" |
对象(而不是函数)或 null |
| "function" |
函数 |
| "symbol" |
符号 |
(2)常见使用方法
console.log(typeof undefined);//'undefined'
console.log(typeof true);//'bpplean'
console.log(typeof ("number")); //'string'
console.log(typeof "number"); //'string'
console.log(typeof 1);//'number'
console.log(typeof Symbol());//'symbol'
//对于Array,Null等特殊对象使用typeof一律返回object,这正是typeof的局限性
console.log(typeof null); //'object'
console.log(typeof [1, 2, 3]);//'object'
console.log(typeof undefined); //'undefined'
//通过 typeof 操作符来区分函数和其他对象
function f1() { console.log(111); }
console.log(typeof f1); //'function'
console.log(typeof f1()); // 111 'undefined'
(3)不能通过typeof 来判断一个变量是否存在
var a;
if (a === undefined) {
console.log("变量不存在")
} else {
console.log("变量存在")
}
// 变量不存在
typeof虽然对原始值很有用,但它对引用值的用处不大。我们通常不关心一个值是不是对象,而是想知道它是什么类型的对象。为了解决这个问题,ECMAScript 提供了 instanceof 操作符。使用如下:
function f1() { console.log(111); }
console.log(f1 instanceof Object);//true
console.log(f1 instanceof Function);//true
console.log(f1 instanceof RegExp);//false
所有引用值都是 Object 的实例,因此通过 instanceof 操作符检测任何引用值和Object 构造函数都会返回 true 。
instanceof 检测原始值,则始终会返回 false ,因为原始值不是对象。instanceof 运算符用于判断构造函数的 prototype 属性是否出现在对象的原型链中的任何位置。其实现原理如下:
function myInstanceof(left, right) {
let proto = Object.getPrototypeOf(left), // 获取对象的原型
prototype = right.prototype; // 获取构造函数的 prototype 对象
// 判断构造函数的 prototype 对象是否在对象的原型链上
while (true) {
if (!proto) return false;
if (proto === prototype) return true;
proto = Object.getPrototypeOf(proto);
}
}
typeof 与 instance 都是判断数据类型的方法,区别如下:
typeof会返回一个变量的基本类型,instanceof返回的是一个布尔值instanceof 可以准确地判断复杂引用数据类型,但是不能正确判断基础数据类型typeof 也存在弊端,它虽然可以判断基础数据类型(null 除外),但是引用数据类型中,除了function 类型以外,其他的也无法判断可以看到,上述两种方法都有弊端,并不能满足所有场景的需求
如果需要通用检测数据类型,建议采用Object.prototype.toString,调用该方法,统一返回格式“[object Xxx]”的字符串。使用如下:
console.log(Object.prototype.toString.call(undefined)) //"[object Undefined]"
console.log(Object.prototype.toString.call(true)) // "[object Boolean]"
console.log(Object.prototype.toString.call('1')) // "[object String]"
console.log(Object.prototype.toString.call(1)) // "[object Number]"
console.log(Object.prototype.toString.call(Symbol())) // "[object Symbol]"
console.log(Object.prototype.toString.call({})) // "[object Object]"
console.log(Object.prototype.toString.call(function () { })) // "[object Function]"
console.log(Object.prototype.toString.call([])) //"[object Array]"
console.log(Object.prototype.toString.call(null)) //"[object Null]"
console.log(Object.prototype.toString.call(/123/g)) //"[object RegExp]"
console.log(Object.prototype.toString.call(new Date())) //"[object Date]"
总结:
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
Javascript查看大图功能代码实现,点击小图片可以查看大图,就是把大图放置在顶层(z-index大于当前页面的),并且还可以加一些额外的比如透明度什么的。
Jquery命名冲突解决办法很简单,只需要给jquery取一个别名即可,传统$命名形式我们都是这样使用jquery的,入下所示: scripttype=text/javascriptjQuery(function($){//thiswillsetthedivstexttoHello.$(#myDiv).text(Hello);});/scriptdivid=myDivText/div
本文实例为大家分享了JS旋转实现转盘抽奖效果的具体代码,供大家参考,具体内容如下闲来没事,做了一个模拟转盘抽奖的HTML&JS的效果:可以在设置的时候,选择几个区域,并且可以填写指针将要停止的区域
本篇文章给大家分享20 个提高代码效率的 JavaScript 技巧和窍门,做一个不加班的前端人,希望对大家有所帮助。
我们在学习JavaScript时,回调函数是很重要的一个知识点,是大家需要掌握的内容。但是很多很多新手对于JavaScript中的回调,并不是很清楚,因此这篇文章就给大家介绍一下回调函数的概念以及如何区分两种回调:同步和异步。
成为群英会员,开启智能安全云计算之旅
立即注册关注或联系群英网络
7x24小时售前:400-678-4567
7x24小时售后:0668-2555666
24小时QQ客服
群英微信公众号
CNNIC域名投诉举报处理平台
服务电话:010-58813000
服务邮箱:service@cnnic.cn
投诉与建议:0668-2555555
Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 ICP核准(ICP备案)粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008