欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  web前端

web开发中怎样检测引用值

程序员文章站 2022-05-31 09:22:43
...
这次给大家带来web开发中怎样检测引用值,web开发中检测引用值的注意事项有哪些,下面就是实战案例,一起来看一下。

引用值也称作对象(object)。在JS中除了原始值之外的值都是引用。有这样几种内置的引用类型:Object、Array、Date和Error,数量不多。typeof运算符在判断这些引用类型时显得力不从心,因为所有对象都会返回"object"。

typeof另外一种不推荐的用法是当检测null的类型时,typeof运算符用于null时将全返回"object"。这看上去很怪异,被认为是标准规范的严重bug,因此在编程时要杜绝使用typeof来检测null的类型。

检测某个引用值的类型的最好方法是使用instanceof运算符。instanceof的基本语法是:value instanceof constructor。

instanceof的一个有意思的特性是它不仅检测构造这个对象的构造器,还检测原型链。原型链包含了很多信息,包括定义对象所采用的继承模式。比如,默认情况下,每个对象都继承自Object,因此每个对象的value instanceof Object都会返回true。因为这个原因,使用value instanceof Object来判断对象是否属于某个特定类型的做法并非最佳。

instanceof运算符也可以检测自定义的类型,比如:

function Person (name) {  this.name = name;
}var me = new Person('Nicholas');console.log(me instanceof Object); // trueconsole.log(me instanceof Person); // true

在JS中检测自定义类型时,最好的做法就是使用instanceof运算符,这也是唯一的方法。同样对于内置JS类型也是如此(使用instanceof运算符)。但是,有一个严重的限制。

假设一个浏览器帧(frameA)里的一个对象被传入到另一个帧(frameB)中。两个帧里都定义了构造函数Person。如果来自帧A的对象是帧A的Person的实例,则如下规则成立。

frameAPersonInstance instanceof frameAPerson; // trueframeAPersonInstance instanceof frameBPerson; // false

因为每个帧(frame)都拥有Person的一份拷贝,它被认为是该帧(frame)中的Person的拷贝实例,尽管两个定义可能完全一样的。这个问题不仅出现在自定义类型身上,其他两个非常重要的内置类型也有这个问题:函数和数组。对于这两个类型来说,一般用不着使用instanceof。

相信看了本文案例你已经掌握了方法,更多精彩请关注其它相关文章!

推荐阅读:

web开发中怎样检测原始值

怎样利用JS做出引用传递与值传递

以上就是web开发中怎样检测引用值的详细内容,更多请关注其它相关文章!

相关标签: web 引用 检测