javascript高级-02

一、原型及原型链

function Person(name,age) {
  //属性
  this.name=name;
  this.age=age;
  //在构造函数中的方法
  this.eat=function () {
    console.log("吃好吃的");
  };
}
//添加共享的属性
Person.prototype.sex="男";
//添加共享的方法
Person.prototype.sayHi=function () {
  console.log("您好啊,怎么这么帅,就是这么帅");
};
//实例化对象,并初始化
var per=new Person("小明",20);
per.sayHi();
//如果想要使用一些属性和方法,并且属性的值在每个对象中都是一样的,方法在每个对象中的操作也都是一样,那么,为了共享数据,节省内存空间,是可以把属性和方法通过原型的方式进行赋值

console.dir(per);//实例对象的结构
console.dir(Person);//构造函数的结构

//实例对象的原型__proto__和构造函数的原型prototype指向是相同的

//实例对象中的__proto__原型指向的是构造函数中的原型prototype
console.log(per.__proto__==Person.prototype);
//实例对象中__proto__是原型,浏览器使用的
//构造函数中的prototype是原型,程序员使用的

//原型链:是一种关系,实例对象和原型对象之间的关系,关系是通过原型(__proto__)来联系的

二、原型的指向是可以改变的

//人的构造函数
function Person(age) {
  this.age=10;
}
//人的原型对象方法
Person.prototype.eat=function () {
  console.log("人的吃");
};
//学生的构造函数
function Student() {

}
Student.prototype.sayHi=function () {
  console.log("嗨,小苏你好帅哦");
};
//学生的原型,指向了一个人的实例对象
Student.prototype=new Person(10);
var stu=new Student();
stu.eat();
stu.sayHi();

//原型指向可以改变
//实例对象的原型__proto__指向的是该对象所在的构造函数的原型对象
//构造函数的原型对象(prototype)指向如果改变了,实例对象的原型(__proto__)指向也会发生改变

//原型的指向是可以改变的
//实例对象和原型对象之间的关系是通过__proto__原型来联系起来的,这个关系就是原型链

原型最终指向了哪里?

//实例对象中有__proto__原型
//构造函数中有prototype原型
//prototype是对象
//所以,prototype这个对象中也有__proto__,那么指向了哪里
//实例对象中的__proto__指向的是构造函数的prototype
//所以,prototype这个对象中__proto__指向的应该是某个构造函数的原型prototype

三、函数中的this的指向

/*
 *
 * 函数中的this的指向
 *
 *
 * 普通函数中的this是谁?-----window
 * 对象.方法中的this是谁?----当前的实例对象
 * 定时器方法中的this是谁?----window
 * 构造函数中的this是谁?-----实例对象
 * 原型对象方法中的this是谁?---实例对象
 *
 *
 * */
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 第3章 基本概念 3.1 语法 3.2 关键字和保留字 3.3 变量 3.4 数据类型 5种简单数据类型:Unde...
    RickCole阅读 5,286评论 0 21
  • 每天晨起读首诗 将诗意裹藏进整日的分分秒秒里 一生都在蔷薇盎然处栖息 日子在我掌心零落成花 盛开在余生的春秋冬夏 ...
    漱绿阅读 680评论 0 3
  • lifeLL阅读 313评论 0 0
  • 上中学的时候总有一个想法,把我的生活记录下来,可惜我只是想法,连每天写日记都不能做到。有了儿子后,为他断断续续写了...
    开心的灵通阅读 144评论 0 0