原型和原型链 prototype和proto的区别详情


Posted in Javascript onNovember 02, 2021

1、原型

原型是function对象下的属性,它定义了构造函数的共同祖先,也就是一个父子级的关系,子对象会继承父对象的方法和属性

  • prototype是函数下的属性,对象想要查看原型使用隐式属性__Proto__
  • constructor指向构造函数
  • 自己身上有属性,原型上也有属性,取近的,用自己的

通过给原型添加属性,可以让所有的实例化对象共享属性和方法

Car.prototype = {
 height : 1400,
 lang : 4900,
 carName : 'BMW'
}
function Car() {
}
var car = new Car();

2、原型链

每个实例对象下都有__proto__属性,通过属性__proto__指向构造函数的原型对象,当到达末端时,返回null,这样一层一层向顶端查找,就形成了原型链

prototype是函数特有的, __proto__是对象有的,js中万物皆对象

prototype——proto——区别与作用

  • prototype把共有属性预先定义好,给之后对象使用
  • prototype的存在实现了继承,节省内存空间
  • __proto__是对象的,prototype是函数的,因为函数也是对象,所以函数也有__proto__
  • __proto__的作用是就是当访问一个对象的属性时,如果该对象内部不存在这个属性,那么就会沿着它的**__proto__**属性所指向的那个对象(父对象)里找,也就是原型链
  • prototype的作用是就是让该函数所实例化的对象们都可以找到公用的属性和方法

__proto__对象原型的意义就在于为对象的查找机制提供一个方向,或者说一条路线,但是它是一个非标准属性,因此实际开发中,不可以使用这个属性,它只是内部指向原型对象 prototype

2.1 constructor构造函数

constructor属性存在于__proto__prototype,它指向构造函数本身

一般情况下,对象的方法都在构造函数的原型对象中设置。如果有多个对象的方法,我们可以给原型对象采取对象形式赋值,但是这样就会覆盖构造函数原型对象原来的内容,这样修改后的原型对象 constructor 就不再指向当前构造函数了。此时,我们可以在修改后的原型对象中,添加一个 constructor 指向原来的构造函数。

问题 :修改了函数的原型对象,constructor的指向是谁

function Star(uname, age) {
     this.uname = uname;
     this.age = age;
 }
 // 很多情况下,我们需要手动的利用constructor 这个属性指回 原来的构造函数
 Star.prototype = {
 // 如果我们修改了原来的原型对象,给原型对象赋值的是一个对象,则必须手动的利用constructor指回原来的构造函数
   constructor: Star, // 手动设置指回原来的构造函数
   sing: function() {
     console.log('我会唱歌');
   },
   movie: function() {
     console.log('我会演电影');
   }
}
var zxy = new Star('张学友', 19);
console.log(zxy)

在修改函数原型时,因为Star.prototype就是一个对象,所以constructor指向构造这个对象的原型,也就是object

2.2 call/apply

通过call``apply可以改变this的指向,借用别人的函数完成自己的功能

区别:call传多个参数 apply传一个参数数组

function Person(name,age,sex) {
    this.name = name;
    this.age = age;
    this.sex = sex;
}
function Student(name,age,sex,tel,grade) {
    //var this = {name: "lin", age: "19", sex: "male", tel: 123, grade: 78}
    Person.call(this,name,age,sex);//通过call改变this的指向这个函数
    //Person.apply(this,[name,age,sex])
    this.tel = tel;
    this.grade = grade;
}
var student = new Student('lin','19','male',123,78);

2.3 new()

  • 创建一个空对象
  • 构造函数的this,继承函数原型
  • this指向构造函数的对象实例,执行构造函数内容为新对象添加属性和方法
  • 返回this
var obj = {}//创建空对象
obj.__proto__ = Person.prototype;//继承作用域
Person.call(obj,)//改变this指向
//这三步是隐式的
var person = new Person();//new操作

到此这篇关于原型和原型链 prototype和proto的区别详情的文章就介绍到这了,更多相关原型和原型链 prototype和proto的区别内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Javascript 相关文章推荐
让iframe子窗体取父窗体地址栏参数(querystring)
Oct 13 Javascript
JavaScript 基础知识 被自己遗忘的
Oct 15 Javascript
jquery实现的省市区三级联动
Apr 02 Javascript
node.js 使用ejs模板引擎时后缀换成.html
Apr 22 Javascript
jQuery+Ajax+PHP+Mysql实现分页显示数据实例讲解
Sep 27 Javascript
基于AngularJS实现页面滚动到底自动加载数据的功能
Oct 16 Javascript
jquery中ajax处理跨域的三大方式
Jan 05 Javascript
使用jquery如何获取时间
Oct 13 Javascript
jQuery实现导航栏头部菜单项点击后变换颜色的方法
Jul 19 jQuery
vue2.0 路由模式mode="history"的作用
Oct 18 Javascript
微信小程序如何获取群聊的openGid以及名称详解
Jul 17 Javascript
Vue this.$router.push(参数)实现页面跳转操作
Sep 09 Javascript
浅谈克隆 JavaScript
Nov 02 #Javascript
WebWorker 封装 JavaScript 沙箱详情
quickjs 封装 JavaScript 沙箱详情
Nov 02 #Javascript
js 数组 fill() 填充方法
浅谈 JavaScript 沙箱Sandbox
详解 TypeScript 枚举类型
Nov 02 #Javascript
前端JavaScript大管家 package.json
You might like
收集的DedeCMS一些使用经验
2007/03/17 PHP
$_GET['goods_id']+0 的使用详解
2013/06/06 PHP
php遍历树的常用方法汇总
2015/06/18 PHP
PHP常用的小程序代码段
2015/11/14 PHP
PHP使用curl函数发送Post请求的注意事项
2016/11/26 PHP
PHP执行shell脚本运行程序不产生core文件的方法
2016/12/28 PHP
用php+ajax新建流程(请假、进货、出货等)
2017/06/11 PHP
PHP时间日期增减操作示例【date strtotime实现加一天、加一月等操作】
2018/12/21 PHP
Jquery中显示隐藏的实现代码分析
2011/07/26 Javascript
jquery实现浮动的侧栏实例
2015/06/25 Javascript
详解JavaScript中的构造器Constructor模式
2016/01/14 Javascript
javascript实现不同颜色Tab标签切换效果
2016/04/27 Javascript
Vuejs第十二篇之动态组件全面解析
2016/09/09 Javascript
jQuery鼠标事件总结
2016/10/13 Javascript
JavaScript ES6中CLASS的使用详解
2016/11/22 Javascript
javascript中的try catch异常捕获机制用法分析
2016/12/14 Javascript
Node.js数据库操作之连接MySQL数据库(一)
2017/03/04 Javascript
Node做中转服务器转发接口
2017/10/18 Javascript
JavaScript中click和onclick本质区别与用法分析
2018/06/07 Javascript
[02:30]DOTA2放量测试专访海涛:呼吁保护新手玩家
2013/08/26 DOTA
Python字符串替换实例分析
2015/05/11 Python
Python+Socket实现基于UDP协议的局域网广播功能示例
2017/08/31 Python
python实现图像拼接
2020/03/05 Python
Win10用vscode打开anaconda环境中的python出错问题的解决
2020/05/25 Python
python初步实现word2vec操作
2020/06/09 Python
HTML5 Canvas实现360度全景图的示例代码
2018/01/29 HTML / CSS
微软英国官方网站:Microsoft英国
2016/10/15 全球购物
Wilson体育用品官网:美国著名运动器材品牌
2019/05/12 全球购物
什么情况下你必须要把一个类定义为abstract的
2013/01/06 面试题
META-INF文件夹中的MANIFEST.MF的作用
2016/06/21 面试题
最新的大学生找工作自我评价
2013/09/29 职场文书
矫正人员思想汇报
2014/01/08 职场文书
公务员转正鉴定材料
2014/02/11 职场文书
群众路线教育实践活动自我剖析思想汇报
2014/10/04 职场文书
观后感开头
2015/06/19 职场文书
企业催款函范本
2015/06/24 职场文书