- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
在 JavaScript 中,in
运算符检查对象是否具有指定的属性。但是,它不仅检查对象自身的属性,还检查原型(prototype)链。因此,在某些情况下,它的行为可能与预期不完全一样。
假设由于某种原因我们有一个对象 someArrayMethods
包含(显然)一些数组方法作为键:
const someArrayMethods = {
indexOf: true,
map: true,
};
in
检查该对象是否具有特定方法作为键。运算符(operator):
console.log('indexOf' in someArrayMethods); // true
console.log('every' in someArrayMethods); // false
toString
会怎样?属性(property)?
console.log('toString' in someArrayMethods); // true
toString
method在原型(prototype)链中,所以
in
运算符返回
true
即使对象没有自己的
toString
属性(property)。
hasOwnProperty()
来救援!和
in
几乎一样运算符,有一个区别:它不检查原型(prototype)链。我们可以重写我们之前的例子:
console.log(someArrayMethods.hasOwnProperty('toString')); // false
hasOwnProperty()
在一种情况下也可能失败。如果我们有一个拥有自己属性的对象
hasOwnProperty
?看这个例子:
const someObject = {
hasOwnProperty() {
return false;
},
theAnswer: 42,
};
// Does `someObject` has own property `theAnswer`?
console.log(someObject.hasOwnProperty('theAnswer')); // false
// Well, it seems it doesn't...
someObject.hasOwnProperty
, 我们可以直接从
Object.prototype
中引用该方法:
const hasOwn = Object.prototype.hasOwnProperty;
console.log(hasOwn.call(someObject, 'theAnswer')); // true
in
运算符会很有用 ?我知道它可以用来检查某个类的实例是否有某种方法,但是在这种情况下,简单地检查该对象是否是该类的实例不是更好吗?
Object.keys()
使用 ECMAScript 2016
Array.prototype.includes()
:
console.log(Object.keys(someObject).includes('theAnswer')); // true
最佳答案
in
是运营商,所以不能被劫持。您不必依赖没有更改或隐藏脚本 Object
, Object.prototype
, Object.prototype.hasOwnProperty
, Object.prototype.hasOwnProperty.call
.
这是了解对象是否具有某些属性的快速方法。我的意思是,如果 obj.foo
可以返回,例如"bar"
即使 foo
属性是继承的,因此能够知道 obj
是否有意义。有那个foo
属性(property)与否,无论是拥有还是继承。
当然,如果我们只有 HasOwnProperty,我们可以(通常)继续调用 [[GetPrototypeOf]] 直到链的末尾,并检查每个对象。但这对代码来说会很乏味,可能比 native in
慢,并且在 ES5 之前是不可能的。
此外,还有根本区别。 in
运算符使用 [[HasProperty]] 内部方法,而 HasOwnProperty 使用 [[GetOwnProperty]]。对于非普通对象,迭代 [[GetOwnProperty]] 和 [[GetPrototypeOf]] 可能会产生与 [[HasProperty]] 不同的结果。
所以是的:in
当您要调用对象的内部 [[HasProperty]] 方法时,运算符很有用。其实除了Reflect.has
,这是唯一正确的方法。
var p = new Proxy({}, {has: function() {
console.log('Hooray!');
return true;
}});
p.hasOwnProperty('foo'); // :(
'foo' in p; // Hooray! :)
关于javascript - 在任何情况下我应该使用 in 运算符而不是 hasOwnProperty()?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40335779/
我是 Java 新手,这是我的代码, if( a.name == b.name && a.displayname == b.displayname && a.linknam
在下面的场景中,我有一个 bool 值。根据结果,我调用完全相同的函数,唯一的区别是参数的数量。 var myBoolean = ... if (myBoolean) { retrieve
我是一名研究 C++ 的 C 开发人员: 我是否正确理解如果我抛出异常然后堆栈将展开直到找到第一个异常处理程序?是否可以在不展开的情况下在任何 throw 上打开调试器(即不离开声明它的范围或任何更高
在修复庞大代码库中的错误时,我观察到一个奇怪的情况,其中引用的动态类型从原始 Derived 类型更改为 Base 类型!我提供了最少的代码来解释问题: struct Base { // some
我正在尝试用 C# 扩展给定的代码,但由于缺乏编程经验,我有点陷入困境。 使用 Visual Studio 社区,我尝试通过控制台读出 CPU 核心温度。该代码使用开关/外壳来查找传感器的特定名称(即
这可能是一个哲学问题。 假设您正在向页面发出 AJAX 请求(这是使用 Prototype): new Ajax.Request('target.asp', { method:"post", pa
我有以下 HTML 代码,我无法在所有浏览器中正常工作: 我试图在移动到
我对 Swift 很陌生。我如何从 addPin 函数中检索注释并能够在我的 addLocation 操作 (buttonPressed) 中使用它。我正在尝试使用压力触摸在 map 上添加图钉,在两
我设置了一个详细 View ,我是否有几个 Nib 文件根据在 Root View Controller 的表中选择的项目来加载。 我发现,对于 Nibs 的类,永远不会调用 viewDidUnloa
我需要动态访问 json 文件并使用以下代码。在本例中,“bpicsel”和“temp”是变量。最终结果类似于“data[0].extit1” var title="data["+bpicsel+"]
我需要使用第三方 WCF 服务。我已经在我的证书存储中配置了所需的证书,但是在调用 WCF 服务时出现以下异常。 向 https://XXXX.com/AHSharedServices/Custome
在几个 SO 答案(1、2)中,建议如果存在冲突则不应触发 INSERT 触发器,ON CONFLICT DO NOTHING 在触发语句中。也许我理解错了,但在我的实验中似乎并非如此。 这是我的 S
如果进行修改,则会给出org.hibernate.NonUniqueObjectException。在我的 BidderBO 类(class)中 @Override @Transactional(pr
我使用 indexOf() 方法来精细地查找数组中的对象。 直到此刻我查了一些资料,发现代码应该无法正常工作。 我在reducer中尝试了上面的代码,它成功了 let tmp = state.find
假设我有以下表格: CREATE TABLE Game ( GameID INT UNSIGNED NOT NULL, GameType TINYINT UNSIGNED NOT NU
代码: Alamofire.request(URL(string: imageUrl)!).downloadProgress(closure: { (progress) in
我是一名优秀的程序员,十分优秀!