深入理解javascript prototype的相关知识


Posted in Javascript onSeptember 19, 2019

如图比较好的阐述了prototype和__proto__

简单的可以这么理解:

狗类A( function foo()),狗类A的模板描述:A.模板 (foo.prototype)是一个对象object, A.模板有个构造方法

foo.prototype.constructor=function foo()

动物B(function function()), 动物B的模板描述 . B.模板 (function.prototype), B.模板有个构造方法

function.prototype.constructor=function function()

狗C= new 狗类A (f1=new foo())

那么狗c的父类模板=A.模板 即 f1.__proto__= foo.prototype.

狗类A的父类模板=B.模板 即 foo.__proto__=function.prototype

只有函数有prototype,对象是没有的。

但是函数也是有__proto__的,因为函数也是对象。函数的__proto__指向的是Function.prototype。

也就是说普通函数是Function这个构造函数的一个实例。

__proto__可以理解为指向父类模板的一个引用。用来查找父类模板的

prototype可以理解为对象的一个属性,用来描述自身如果作为模板是如何定义的,该模板有方法和属性。

function foo() 自身如果作为模板prototype,它自身会有构建函数,模板的属性constructor就是描述这个构建函数。

foo()这个对象实际上是隐含从父类模板继承过来的,这个父类模板就是function function()的模板属性。即它的prototype.

深入理解javascript prototype的相关知识

设计者定义的时候名称比较混淆不利于理解。这是javascript的败笔。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
一个不错的字符串转码解码函数(自写)
Jul 31 Javascript
javascript获取当前鼠标坐标的方法
Jan 10 Javascript
jquery+easeing实现仿flash的载入动画
Mar 10 Javascript
jQuery插件Elastislide实现响应式的焦点图无缝滚动切换特效
Apr 12 Javascript
基于JavaScript实现全屏透明遮罩div层锁屏效果
Jan 26 Javascript
分享我对JS插件开发的一些感想和心得
Feb 04 Javascript
jquery+ajax实现直接提交表单实例分析
Jun 17 Javascript
javascript特殊文本输入框网页特效
Sep 13 Javascript
bootstrap table复杂操作代码
Nov 01 Javascript
前端跨域的几种解决方式总结(推荐)
Aug 16 Javascript
原生js实现省市区三级联动代码分享
Feb 12 Javascript
JavaScript异步操作的几种常见处理方法实例总结
May 11 Javascript
基于Vue的商品主图放大镜方案详解
Sep 19 #Javascript
vue 实现模糊检索并根据其他字符的首字母顺序排列
Sep 19 #Javascript
微信小程序错误this.setData报错及解决过程
Sep 18 #Javascript
解决layui富文本编辑器图片上传无法回显的问题
Sep 18 #Javascript
layui 富文本赋值,取值,取纯文本值的实例
Sep 18 #Javascript
layui 富文本编辑器和textarea值的相互传递方法
Sep 18 #Javascript
微信小程序获取地理位置及经纬度授权代码实例
Sep 18 #Javascript
You might like
浅谈电磁辐射对健康的影响
2021/03/01 无线电
php5 图片验证码实现代码
2009/12/11 PHP
解析php中eclipse 用空格替换 tab键
2013/06/24 PHP
php中用memcached实现页面防刷新功能
2014/08/19 PHP
ThinkPHP基本的增删查改操作实例教程
2014/08/22 PHP
php在apache环境下实现gzip配置方法
2015/04/02 PHP
session 加入redis的实现代码
2016/07/15 PHP
php实现图片按比例截取的方法
2017/02/06 PHP
Smarty缓存机制实例详解【三种缓存方式】
2019/07/20 PHP
类似GMAIL的Ajax信息反馈显示
2010/02/16 Javascript
javascript,jquery闭包概念分析
2010/06/19 Javascript
jQuery+JSON+jPlayer实现QQ空间音乐查询功能示例
2013/06/17 Javascript
JQuery操作单选按钮以及复选按钮示例
2013/09/23 Javascript
DOM基础教程之使用DOM + Css
2015/01/20 Javascript
Position属性之relative用法
2015/12/14 Javascript
JS表单验证的代码(常用)
2016/04/08 Javascript
animate 实现滑动切换效果【实例代码】
2016/05/05 Javascript
深入理解Angular2 模板语法
2016/08/07 Javascript
微信小程序 参数传递详解
2016/10/24 Javascript
ES6中Iterator与for..of..遍历用法分析
2017/03/31 Javascript
详解从买域名到使用pm2部署node.js项目全过程
2018/03/07 Javascript
webpack4.0打包优化策略整理小结
2018/03/30 Javascript
webpack公共组件引用路径简化小技巧
2018/06/15 Javascript
使用vue-router与v-if实现tab切换遇到的问题及解决方法
2018/09/07 Javascript
微信小程序 行的删除和增加操作实现详解
2019/09/29 Javascript
[01:32]2016国际邀请赛中国区预选赛IG战队首日赛后采访
2016/06/27 DOTA
python批量修改图片后缀的方法(png到jpg)
2018/10/25 Python
Python判断对象是否相等及eq函数的讲解
2019/02/25 Python
localstorage和sessionstorage使用记录(推荐)
2017/05/23 HTML / CSS
美国在线工具商店:Acme Tools
2018/06/26 全球购物
自动化职业生涯规划书范文
2014/01/03 职场文书
大学活动邀请函
2014/01/28 职场文书
迎元旦广播稿
2014/02/22 职场文书
小学教师师德师风个人整改措施
2014/09/18 职场文书
2014年教务处工作总结
2014/12/03 职场文书
幼儿园教师节活动总结
2015/03/23 职场文书