浅谈Object.prototype.hasOwnProperty.call(a, b)

前言

Object.prototype.hasOwnProperty.call 是 JavaScript 中一种常用的方式来检查一个对象是否具有某个特定的自有属性(即不是继承自原型链的属性)。它结合了 Object.prototype.hasOwnProperty 方法和 Function.prototype.call 方法来实现这一功能。

1. Object.prototype.hasOwnProperty

  • 作用hasOwnPropertyObject.prototype 上的一个方法,用于检查一个对象是否具有某个指定的自有属性(即直接定义在对象上的属性,而不是从原型链继承的属性)。
  • 用法object.hasOwnProperty(prop),其中 object 是要检查的对象,prop 是要检查的属性名。

例如:

javascript 复制代码
const obj = { a: 1 };
console.log(obj.hasOwnProperty("a")); // true,因为 "a" 是 obj 的自有属性
console.log(obj.hasOwnProperty("toString")); // false,因为 "toString" 是从原型链继承的

2. Function.prototype.call

  • 作用call 方法用于调用一个函数,并显式地指定函数的上下文(this 值),同时还可以传递参数。
  • 用法function.call(thisArg, arg1, arg2, ...),其中 thisArg 是函数执行时的上下文,arg1arg2 等是传递给函数的参数。

例如:

javascript 复制代码
function greet(name) {
  return `Hello, ${name}! I am ${this.name}`;
}
const person = { name: "jjq" };
console.log(greet.call(person, "jiangjianqing")); // "Hello, jiangjianqing! I am jjq"

3. Object.prototype.hasOwnProperty.call

Object.prototype.hasOwnPropertyFunction.prototype.call 结合起来,可以实现以下功能:

  • 作用 :通过 call 方法,将 Object.prototype.hasOwnProperty 方法绑定到任意对象上(调用Object.prototype上的hasOwnProperty方法并将上下文与自定义的内容相互绑定,其作用就像是Object.prototype上的hasOwnProperty暂时性地绑定到了自定义的内容上!!从而避免某些恶意代码 故意污染某些方法),并检查该对象是否具有某个自有属性。这种方式可以避免直接在对象上调用 hasOwnProperty 时可能遇到的问题,例如对象本身覆盖了 hasOwnProperty 方法。
  • 用法Object.prototype.hasOwnProperty.call(object, prop),其中 object 是要检查的对象,prop 是要检查的属性名。

示例

javascript 复制代码
const obj = { a: 1, hasOwnProperty: function() { return false; } };// 假设此处有恶意代码污染了hasOwnProperty方法

// 直接调用 obj.hasOwnProperty 会返回 false,因为 obj 自己覆盖了 hasOwnProperty 方法
console.log(obj.hasOwnProperty("a")); // false

// 使用 Object.prototype.hasOwnProperty.call 来检查(❗❗注意 我调用的是Object.prototype上的hasOwnProperty方法,然后临时绑定了这个方法执行时候的上下文,所以不用担心原型污染问题!!!)
console.log(Object.prototype.hasOwnProperty.call(obj, "a")); // true

在这个例子中,obj 自己覆盖了 hasOwnProperty 方法,导致直接调用 obj.hasOwnProperty 时无法正确检查属性。而通过 Object.prototype.hasOwnProperty.call,可以绕过对象自身的覆盖 ,直接使用原型链上的 hasOwnProperty 方法,从而正确检查自有属性

总结

Object.prototype.hasOwnProperty.call 是一种安全、可靠的方式来检查对象的自有属性,尤其适用于需要避免对象自身覆盖原型方法的场景。它利用了 call 方法的上下文绑定特性,确保始终使用原型链上的 hasOwnProperty 方法进行检查。

收摊!🫏🫏🫏

相关推荐
云上凯歌5 分钟前
02 Spring Boot企业级配置详解
android·spring boot·后端
夏天想5 分钟前
element-plus的输入数字组件el-input-number 显示了 加减按钮(+ -) 和 小三角箭头(上下箭头),怎么去掉+,-或者箭头
前端·javascript·vue.js
秋饼18 分钟前
【手撕 @EnableAsync:揭秘 SpringBoot @Enable 注解的魔法开关】
java·spring boot·后端
IT_陈寒26 分钟前
Python 3.12 新特性实战:这5个改进让我的开发效率提升40%
前端·人工智能·后端
利兄的视界27 分钟前
一步到位:M4 芯片 Mac 安装 PostgreSQL 16 并适配 pgvector 教程
后端·postgresql
GZKING28 分钟前
ThinkPHP 8 报错"think\model\pivot" not found
后端
清风徐来QCQ1 小时前
SpringMvC
前端·javascript·vue.js
Smoothzjc1 小时前
👉 求你了,别再裸写 fetch 做 AI 流式响应了!90% 的人都在踩这个坑
前端·人工智能·后端
Swift社区1 小时前
ArkTS Web 组件里,如何通过 javaScriptProxy 让 JS 同步调用原生方法
开发语言·前端·javascript
superman超哥1 小时前
Rust 或模式(Or Patterns)的语法:多重匹配的优雅表达
开发语言·后端·rust·编程语言·rust或模式·or patterns·多重匹配