构造函数、实例、原型、原型链

文章目录

  • 1.学习目的
  • 2.构造函数和实例对象
    • 2.1 定义
    • 2.2 作用
    • 2.3 构造函数缺陷:内存浪费
    • 2.4 解决方法
      • (1)使用全局变量声明函数(造成全局变量污染)
      • (2)使用对象,解决内存浪费和变量污染(该对象变成污染源):原型前身
  • 3.原型
  • 4.构造函数、实例对象、原型的关系
  • 5.原型链

1.学习目的

共享属性和方法,节约内存资源,防止变量污染

2.构造函数和实例对象

function Person(){}
var person1 = new Person()
var person2 = new Person()

2.1 定义

当用new去调用一个函数时,如上代码所示,
new Person()就是构造函数person1,person2就是实例对象

2.2 作用

一个构造函数可以有多个实例对象(一对多),这样可以生成多个相同属性、不同值的对象,如:
image.png

2.3 构造函数缺陷:内存浪费

function Person(name,age){
  this.name = name;
  this.age = age;
  this.sex = '男'
  this.say = function(){
    console.log('say')
  }
}
var p1 = new Person('张三',18);//创建新内存 地址
var p2 = new Person('李四',20);//创建新内存,每次生成实例对象属性sex和方法say都重复生成,造成内存浪费
console.log(p1.say == p2.say)//false

构造函数执行过程:
new Person():创建新的内存空间 --》this指向该内存 --》 执行函数体代码 --》 默认返回this
每次生成实例对象属性sex方法say都重复生成,造成内存浪费

2.4 解决方法

(1)使用全局变量声明函数(造成全局变量污染)

let say = function(){
  console.log('say')
}
function Person(){
  this.say = say
}
let p1 = new Person()
let p2 = new Person()
console.log(p1.say == p2.say)//true

(2)使用对象,解决内存浪费和变量污染(该对象变成污染源):原型前身

let obj = {
  say:function(){}
}
function Person(){
  this.say = obj.say
}

3.原型

解决构造函数 浪费内存和变量污染的问题

function Person(name,age){
  this.name = name;
  this.age = age;
  }
}
Person.prototype.sex = '男'
Person.prototype.say = function(){
  console.log('say')
}
var p1 = new Person('张三',18);//创建新内存 地址
var p2 = new Person('李四',20);//创建新内存 地址
console.log(p1.say == p2.say)//true

4.构造函数、实例对象、原型的关系

console.log(person1.__proto__ === Person.prototype)//true
console.log(Person === Person.prototype.constructor)//true

5.原型链

console.log(Object.getPrototypeOf(Person) === Person.prototype)//true
console.log(Person.prototype.__proto__ === Object.prototype)//


__proto__不是web标准,很多浏览器不显示,在开发中不使用,只用于学习研究

  • 7
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

秋子aria

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值