深入理解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 相关文章推荐
jQuery中使用了document和window哪些属性和方法小结
Sep 13 Javascript
js截取小数点后几位的写法
Nov 14 Javascript
node.js中的buffer.Buffer.isEncoding方法使用说明
Dec 14 Javascript
JavaScript中的this引用(推荐)
Aug 05 Javascript
JavaScript数据操作_浅谈原始值和引用值的操作本质
Aug 23 Javascript
Html5 js实现手风琴效果
Apr 17 Javascript
vue中如何引入jQuery和Bootstrap
Apr 10 jQuery
javascript简单写的判断电话号码实例
May 24 Javascript
javascript实现二叉树的代码
Jun 08 Javascript
Angularjs自定义指令实现分页插件(DEMO)
Sep 16 Javascript
微信小程序实现文字跑马灯效果
May 26 Javascript
vue轮播图插件vue-concise-slider的使用
Mar 13 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
PHP生成Flash动画的实现代码
2010/03/12 PHP
Javascript 面向对象 对象(Object)
2010/05/13 Javascript
P3P Header解决Cookie跨域的问题
2013/03/12 Javascript
jquery 日期控件datepicker属性详细解析
2013/11/08 Javascript
javascript对话框使用方法(警告框 javascript确认框 提示框)
2014/01/07 Javascript
浅析JQuery中的html(),text(),val()区别
2014/09/01 Javascript
javascript手工制作悬浮菜单
2015/02/12 Javascript
JS实现网页顶部向下滑出的全国城市切换导航效果
2015/08/22 Javascript
BootStrap智能表单实战系列(七)验证的支持
2016/06/13 Javascript
javascript的replace方法结合正则使用实例总结
2016/06/16 Javascript
jQuery获取多种input值的简单实现方法
2016/06/20 Javascript
使用vux实现上拉刷新功能遇到的坑
2018/02/08 Javascript
微信小程序如何调用图片接口API并居中显示
2019/06/29 Javascript
vue 实现强制类型转换 数字类型转为字符串
2019/11/07 Javascript
Node.js API详解之 Error模块用法实例分析
2020/05/14 Javascript
Vue在H5 项目中使用融云进行实时个人单聊通讯
2020/12/14 Vue.js
vue 数据操作相关总结
2020/12/17 Vue.js
Ubuntu 14.04+Django 1.7.1+Nginx+uwsgi部署教程
2014/11/18 Python
在双python下设置python3为默认的方法
2018/10/31 Python
pycharm运行程序时在Python console窗口中运行的方法
2018/12/03 Python
django写用户登录判定并跳转制定页面的实例
2019/08/21 Python
Django框架表单操作实例分析
2019/11/04 Python
Python解压 rar、zip、tar文件的方法
2019/11/19 Python
Python SMTP配置参数并发送邮件
2020/06/16 Python
HTML5单页面手势滑屏切换原理
2016/03/21 HTML / CSS
美国乡村商店:Plow & Hearth
2016/09/12 全球购物
模具设计与制造专业推荐信
2014/02/16 职场文书
环保小标语
2014/06/13 职场文书
大学生工作自荐书
2014/06/16 职场文书
业务员辞职信范文
2015/03/02 职场文书
求职信范文怎么写
2015/03/19 职场文书
2015年小学数学教研组工作总结
2015/05/21 职场文书
中学教师教学工作总结
2015/08/13 职场文书
Nginx+Tomcat实现负载均衡、动静分离的原理解析
2021/03/31 Servers
Python中json.load()和json.loads()有哪些区别
2021/06/07 Python
Python中Matplotlib的点、线形状、颜色以及绘制散点图
2022/04/07 Python