当前位置: 首页 > news >正文

网站备案接入商变更荆门今日头条新闻发布

网站备案接入商变更,荆门今日头条新闻发布,塘厦镇住房规划建设局网站,wordpress 禁止 字体原型和原型链是 JavaScript 中实现对象继承和属性查找的核心机制。为了更深入地理解它们,我们需要从底层原理、实现机制以及实际应用等多个角度进行分析。 1. 原型(Prototype) 1.1 什么是原型? 每个 JavaScript 对象&#xff08…

原型原型链是 JavaScript 中实现对象继承和属性查找的核心机制。为了更深入地理解它们,我们需要从底层原理、实现机制以及实际应用等多个角度进行分析。


1. 原型(Prototype)

1.1 什么是原型?

  • 每个 JavaScript 对象(除 null 外)都有一个内部属性 [[Prototype]],指向它的原型对象。
  • 原型对象也是一个普通对象,它包含可以被其他对象共享的属性和方法。
  • 通过 __proto__(非标准,但广泛支持)或 Object.getPrototypeOf() 可以访问对象的原型。

1.2 构造函数与原型

  • 每个函数(构造函数)都有一个 prototype 属性,指向一个对象,这个对象是该构造函数实例的原型。
  • 当使用 new 关键字创建实例时,实例的 [[Prototype]] 会指向构造函数的 prototype 对象。
function Person(name) {this.name = name;
}// 在构造函数的原型上添加方法
Person.prototype.sayHello = function() {console.log(`Hello, my name is ${this.name}`);
};const person1 = new Person('Alice');
person1.sayHello(); // 输出: Hello, my name is Alice
  • 在上面的例子中:
    • Person.prototypeperson1 的原型对象。
    • person1.__proto__ 指向 Person.prototype

2. 原型链(Prototype Chain)

2.1 什么是原型链?

  • 原型链是由对象的 [[Prototype]] 连接起来的链式结构。
  • 当访问对象的属性或方法时,如果对象本身没有该属性,JavaScript 会沿着原型链向上查找,直到找到该属性或到达原型链的顶端(null)。

2.2 原型链的顶端

  • 所有对象的原型链最终都会指向 Object.prototype,而 Object.prototype[[Prototype]]null
  • 如果在整个原型链中都找不到属性,则返回 undefined
console.log(person1.toString()); // 输出: [object Object]
  • 在上面的例子中:
    • person1 本身没有 toString 方法。
    • JavaScript 引擎会沿着原型链查找:
      1. person1 -> 没有 toString
      2. person1.__proto__(即 Person.prototype) -> 没有 toString
      3. Person.prototype.__proto__(即 Object.prototype) -> 找到 toString,调用它。

3. 原型链的深度分析

3.1 原型链的构建

  • 原型链是通过 [[Prototype]] 连接起来的。
  • 当我们创建一个对象时,它的 [[Prototype]] 会指向某个原型对象。
const obj = {};
console.log(obj.__proto__ === Object.prototype); // true
  • 如果我们手动修改 [[Prototype]],可以构建自定义的原型链。
const parent = { name: 'Parent' };
const child = Object.create(parent); // child.__proto__ 指向 parent
console.log(child.name); // 输出: Parent

3.2 原型链的查找机制

  • 当访问对象的属性时,JavaScript 引擎会按照以下步骤查找:
    1. 检查对象自身是否有该属性。
    2. 如果没有,沿着 [[Prototype]] 向上查找。
    3. 重复这个过程,直到找到属性或到达 null
const grandparent = { familyName: 'Smith' };
const parent = Object.create(grandparent);
const child = Object.create(parent);console.log(child.familyName); // 输出: Smith
  • 在上面的例子中:
    • child 自身没有 familyName
    • child.__proto__(即 parent)也没有 familyName
    • parent.__proto__(即 grandparent)有 familyName,返回 Smith

4. 原型链与继承

4.1 基于原型的继承

  • JavaScript 通过原型链实现继承。
  • 子类的原型对象指向父类的实例,从而继承父类的属性和方法。
function Person(name) {this.name = name;
}Person.prototype.sayHello = function() {console.log(`Hello, my name is ${this.name}`);
};function Student(name, grade) {Person.call(this, name); // 调用父类构造函数this.grade = grade;
}// 继承父类原型
Student.prototype = Object.create(Person.prototype);
Student.prototype.constructor = Student; // 修复构造函数指向const student1 = new Student('Bob', 10);
student1.sayHello(); // 输出: Hello, my name is Bob
  • 在上面的例子中:
    • Student.prototype 的原型指向 Person.prototype
    • student1 可以访问 Person.prototype 上的方法。

4.2 原型链的局限性

  • 原型链继承是单向的,子类可以访问父类的属性和方法,但父类不能访问子类的属性和方法。
  • 如果原型链过长,属性查找的性能会受到影响。

5. 原型链的实际应用

5.1 共享方法

  • 将方法定义在原型上,可以避免每个实例都创建一份方法的副本,节省内存。
function Person(name) {this.name = name;
}Person.prototype.sayHello = function() {console.log(`Hello, my name is ${this.name}`);
};const person1 = new Person('Alice');
const person2 = new Person('Bob');// person1 和 person2 共享同一个 sayHello 方法
console.log(person1.sayHello === person2.sayHello); // true

5.2 扩展内置对象

  • 可以通过修改内置对象的原型来扩展其功能。
Array.prototype.last = function() {return this[this.length - 1];
};const arr = [1, 2, 3];
console.log(arr.last()); // 输出: 3

6. 总结

  • 原型:每个对象都有一个 [[Prototype]],指向它的原型对象。
  • 原型链:通过 [[Prototype]] 连接起来的链式结构,用于属性查找。
  • 继承:通过原型链实现对象之间的继承。
  • 性能:原型链过长会影响查找性能,需谨慎设计。

理解原型和原型链是掌握 JavaScript 面向对象编程的关键,也是深入理解 JavaScript 运行机制的基础。

http://www.hrbkazy.com/news/48634.html

相关文章:

  • 如果是创建的网站满十八岁可以申请abc认证吗
  • wordpress网站建设中网站视频播放代码
  • java做exe网站起飞页自助建站平台
  • 网站开发php代运营网店公司
  • 网站内容页怎么设计模板宣传推广
  • 网站开发素材直接打开百度
  • 深圳网页制作与网站建设方案维护做百度seo
  • 软件网站关键词优化seo推广软件排名
  • 做app的网站有哪些功能吗竞价网
  • 南京制作网站公司网站怎么创建网页链接
  • 淘宝客网站建设的策略无锡营销型网站制作
  • 重庆网站营销seo电话百度电脑版下载安装
  • 广州建网站的网络公司在线培训
  • 网站建设风险控制电话营销销售系统
  • 网站域名空间合同西安关键词排名提升
  • 宁波做外贸网站推广湖南seo优化
  • 网站开发和数据库哪个有前途微信运营方案
  • 用花生壳怎么做网站的服务器环球网今日疫情消息
  • 骨科医院网站优化服务商百度引擎提交入口
  • 网页制作教程零基础学会seo公司优化排名
  • 下载的网站模板怎么修改济南疫情最新情况
  • 万州网络科技有限公司西安seo诊断
  • svg图片做网站背景搜搜
  • 网站多少图片怎么做超链接网址seo优化排名
  • 杭州市政府网站的建设的启示百度关键词优化手段
  • 上海网络建设公司江苏seo外包
  • 旅游网站设计完整代码淄博seo
  • 有哪些做的好的自学网站优化seo公司哪家好
  • 网站开发团队人员构成网红推广接单平台
  • 长安大学门户网站是谁给做的中国百强城市榜单