您现在的位置是:亿华云 > 数据库
前端百题斩之Typeof和Instanceof
亿华云2025-10-04 03:55:10【数据库】6人已围观
简介1.1 typeof1.1.1 基础介绍typeof是一个运算符,其有两种使用方式:(1)typeof(表达式);(2)typeof 变量名;返回值是一个字符串,用来说明变量的数据类型;所以可以用此来
1.1 typeof
1.1.1 基础介绍
typeof是前端一个运算符,其有两种使用方式:(1)typeof(表达式);(2)typeof 变量名;返回值是百题一个字符串,用来说明变量的前端数据类型;所以可以用此来判断number, string, object, boolean, function, undefined, symbol 这七种类型,每种情况返回的百题内容如下表所示:
类型 结果 String string Number number Boolean boolean Undefined undefined Object object function函数 function Symbol symbol1.1.2 原理进阶
typeof方法虽然很好用,但该方法有一定的前端局限性:对于对象、数组、百题null 返回的前端值是 object。比如typeof(window),百题typeof(document),前端typeof(null)返回的百题值都是object,这是前端为什么呢?这就要从底层说起。js在底层存储变量的百题时候,会在变量的前端机器码的低位1-3位存储其类型信息:
000:对象; 010:浮点数; 100:字符串; 110:布尔值; 1:整数; 特例:(1)null所有机器码均为0
(2)undefined:用 ?2^30 整数来表示
typeof就是通过机器码判断类型,站群服务器由于null的百题所有机器码均为0,该机器码和对象一样,前端因此直接被当作对象来看待,所以通过typeof就不能够判断区分对象还有null了。
1.1.3 实验
说了这么多,还没有进行验证,下面就逐一验证一下:
// 字符串 console.log(typeof(lili)); // string // 数字 console.log(typeof(1)); // number // 布尔值 console.log(typeof(true)); // boolean // undefined console.log(typeof(undefined)); // undefined // 对象 console.log(typeof({ })); // object // 数组 console.log(typeof([])); // object // null console.log(typeof(null)); // object // 函数 console.log(typeof(() => { })); // function // Symbol值 console.log(typeof(Symbol())); // symbol1.2 instanceof
1.2.1 基础介绍
instanceof运算符用于检测构造函数的 prototype属性是否出现在某个实例对象的原型链上,返回值为布尔值,用于指示一个变量是否属于某个对象的实例。其语法如下所示:
object instanceof constructor1.2.2 原理进阶
instanceof 主要的实现原理就是只要右边变量的 prototype 在左边变量的原型链上即可。因此,instanceof 在查找的过程中会遍历左边变量的原型链,直到找到右边变量的 prototype,如果查找失败,亿华云计算则会返回 false.步骤如下所示:
获取左边变量的隐式原型(即:__ proto __ ,可通过Object.getPrototypeOf()获取); 获取右边变量的显示原型(即:prototype); 进行判断,比较leftVal. __ proto __ . __ proto __ …… === rightVal.prototype,相等则返回true,否则返回false。1.2.3 实验
上面讲述了instanceof的简单使用和其原理,下面简单使用一下并验证一下该原理:
const arr = [1, 2]; // 判断Object的prototype有没有在数组的原型链上 console.log(arr instanceof Object); // true // 数组arr的原型 const proto1 = Object.getPrototypeOf(arr); console.log(proto1); // [] // 数组arr的原型的原型 const proto2 = Object.getPrototypeOf(proto1); console.log(proto2); // [] // Object的prototype console.log(Object.prototype); // 判断arr的原型是否与Object的prototype相等 console.log(proto1 === Object.prototype); // false // 判断arr的原型的原型是否与Object的prototype相等 console.log(proto2 === Object.prototype); // true本文转载自微信公众号「执鸢者」,可以通过以下二维码关注。转载本文请联系执鸢者公众号。
很赞哦!(397)
相关文章
- 众所周知,com域名拥有最大的流通市场和流通历史。最好选择com域名,特别是在购买域名时处理域名。其次可以是cn域名、net域名、org域名等主流域名,现在比较流行的王域名和顶级域名,都是值得注册和投资的。
- 写中断程序要注意哪些方面?
- 为什么要让你的代码尽可能简单
- 值得了解的六大优秀JavaScript图表库
- 3、不明先知,根据相关征兆预测可能发生的事件,以便提前做好准备,赶紧注册相关域名。;不差钱域名;buchaqian抢先注册,就是这种敏感类型。预言是最敏感的状态。其次,你应该有眼力。所谓眼力,就是善于从社会上时不时出现的各种热点事件中获取与事件相关的域名资源。眼力的前提是对域名领域的熟悉和丰富的知识。
- 遇到代码缺陷不要慌,马上教你快速检测和修复
- 新的量子算法破解了非线性方程,计算机能否代替人类成为先知?
- 设计模式,一看就懂的桥模式,解耦可变量与主体逻辑
- 为什么说注册域名注意细节?哪些我们不能忽视?
- 链表基础之LeetCode题解