位置: 编程技术 - 正文

学习javascript面向对象 理解javascript原型和原型链(javascript怎么学好)

编辑:rootadmin

推荐整理分享学习javascript面向对象 理解javascript原型和原型链(javascript怎么学好),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:javascript怎么学好,javascript该怎么学,javascript该怎么学,javascript要怎么学,javascript怎么学,javascript学到什么程度,javascript学了有什么用,javascript学了有什么用,内容如对您有帮助,希望把文章链接给更多的朋友!

先看一张图,梳理梳理。

一、基本概念  【原型链】每个构造函数都有一个对象,原型对象都包含一个指向构造函数的指针,而实例都包含一个指向原型对象的内部指针。那么,如果原型对象等于另一个原型的实例,此时的原型对象将包含一个指向另一个原型的指针,相应地,另一个原型中也包含着一个指向另一个构造函数的指针。如果另一个原型又是另一个原型的实例,那么上述关系依然成立。如此层层递进,就构成了实例与原型的链条。【原型对象】这个对象包含可以由特定类型的所有实例共享的属性和方法。所有引用类型默认都继承了Object,而这个继承也是通过原型链实现的。所有函数的默认原型都是Object的实例,因此默认原型都会包含一个内部指针,指向Object.prototype,这也正是所有自定义类型都会继承toString()、valueOf()方法的原因【构造函数】构造函数与其他函数的区别在于调用它们的方式不同。一般来说,函数只要通过new操作符来调用,那它就可以作为构造函数;如果不通过new操作符来调用,那它跟普通函数也不会有什么两样。[注意]用户自定义的函数和javascript中内置的构造函数可以当成构造函数使用【构造函数的写法】构造函数始终应该以一个大写字母开头,而非构造函数以一个小写字母开头。这个做法借鉴自其他OO语言,主要是为了区别于ECMAScript中的其他函数;因为构造函数本身也是函数,只不过可以用来创建对象而已【构造函数的三种使用场景】[a]当作构造函数使用

[b]当作普通函数调用

[c]在另一个对象的作用域中调用

【prototype属性】只要创建了一个新函数,就会根据一组特定的规则为该函数创建一个prototype属性,这个属性指向函数的原型对象。[注意]只有函数才有prototype属性,object没有prototype属性【constructor属性】在默认情况下,所有原型对象都会自动获得一个constructor(构造函数)属性,这个属性包含一个指向prototype属性所在函数的指针[注意]创建了自定义的构造函数之后,其原型对象默认只会取得constructor属性,至于其他方法则都是从Object继承而来的【_proto_和[[prototype]]】当调用构造函数创建一个新实例后,该实例的内部将包含一个指针(内部属性),指向构造函数的原型对象。ECMA-第5版管这个指针叫[[prototype]]。虽然在脚本中标准的方式访问[[prototype]],但firefoxsafarichrome在每个对象上都支持一个属性_proto_;而在其他实现中,这个属性对脚本则是完全不可见的。这个连接存在于实例与构造函数的原型对象之间,而不是存在于实例与构造函数之间二、基本操作  【原型链查询】每当代码读取某个对象的某个属性时,都会执行一次搜索,目标是具有给定名字的属性。搜索首先从对象实例本身开始,如果在实例中找到了具有给定名字的属性,则返回该属性的值;如果没有找到,则继续搜索指针指向的原型对象,在原型对象中查找具有给定名字的属性,如果找到了这个属性,则返回该属性的值。【添加实例属性】当为对象实例添加一个属性时,这个属性就会屏蔽原型对象中保存的同名属性;换句话说,添加这个属性只会阻止我们访问原型中的那个属性,但不会修改那个属性,即使将这个属性设置为null,也只会在实例中设置这个属性,而不会恢复其指向原型的连接。不过,使用delete操作符则可以完全删除实例属性,从而让我们能够重新访问原型中的属性。【原型的动态性】由于在原型中查找值的过程是一次搜索,因此我们对原型对象所做的任何修改都能立即从实例上反映出来,即使是先创建了实例后修改原型也照样如此。[注意]不推荐在产品化的程序中修改原生对象的原型

【重写原型】调用构造函数时会为实例添加一个指向最初原型的[[prototype]]指针,而把原型修改为另外一个对象就等于切断了构造函数与最初原型之间的联系。实例中的指针仅指向原型,而不指向构造函数。三、基本方法  [1]isPrototypeOf():判断实例对象和原型对象是否存在于同一原型链中,只要是原型链中出现过的原型,都可以说是该原型链所派生的实例的原型

学习javascript面向对象 理解javascript原型和原型链(javascript怎么学好)

[2]ECMAScript5新增方法Object.getPrototypeOf():这个方法返回[[Prototype]]的值

[3]hasOwnProperty():检测一个属性是否存在于实例中

[4]ECMAScript5的Object.getOwnPropertyDescriptor():只能用于取得实例属性的描述符,要取得原型属性的描述符,必须直接在原型对象上调用Object.getOwnPropertyDescription()方法

[5]in操作符:在通过对象能够访问给定属性时返回true,无论该属性存在于实例还是原型中

[6]同时使用hasOwnProperty()方法和in操作符,来确定属性是否存在于实例中

[7]ECMAScript5的Object.keys()方法:接收一个对象作为参数,返回一个包含所有可枚举属性的字符串数组[注意]一定要先new出实例对象再使用该方法,否则为空

[8]ECMAScript5的Object.getOwnPropertyNames()方法:接收一个对象作为参数,返回一个包含所有属性的字符串数组[注意]一定要先new出实例对象再使用该方法,否则只有constructor

希望本文所述对大家学习javascript程序设计有所帮助。

详解Bootstrap四种图片样式 在本章中,我们将学习Bootstrap对图片的支持。Bootstrap提供了四个可对图片应用简单样式的class,分别是:img-rounded添加border-radius:6px来获得图片圆角img-circ

详解Bootstrap按钮 描述BootstrapButton(按钮)JavaScript插件允许您加强按钮的功能。您可以控制按钮的状态,也可以为组件创建按钮组,比如工具条。什么是必需的您必须引

详解Bootstrap glyphicons字体图标 本章将讲解字体图标(Glyphicons),并通过一些实例了解它的使用。Bootstrap捆绑了多种字体格式的字形。首先让我们先来理解一下什么是字体图标。首先

标签: javascript怎么学好

本文链接地址:https://www.jiuchutong.com/biancheng/384693.html 转载请保留说明!

上一篇:详解Bootstrap创建表单的三种格式(一)(bootstrapping怎么做)

下一篇:详解Bootstrap四种图片样式

  • 计提印花税会计凭证怎么做
  • 增值税专用发票的税率是多少啊
  • 生产型企业付的消防年检费记什么科目
  • 用党委经费买的固定资产如何计提?
  • 国外出差差旅费
  • 购置办公大楼
  • 平行登记要求总账
  • 跨月未抵扣的专用发票开红字发票
  • 超过180天增票不抵扣财务还可以入账吗?
  • 17点增值税发票能开吗
  • 个人生产经营所得
  • 小微企业免征增值税条件
  • 汇算清缴需要调增的费用
  • 公司注销要给钱吗
  • 记账凭证填制的内容
  • 发票遗失登报费用账务处理
  • 科技开发属于什么产品
  • 收到利息收入会计分录怎么写
  • 个体户对私账户
  • windows11家庭版本地策略组
  • 怎么利用喜欢自己的人
  • 事业单位财务预算管理制度
  • 不良资产核销的影响
  • PHP:pg_connection_status()的用法_PostgreSQL函数
  • 收外汇的账务处理实例
  • 会计准则 职工福利
  • 建筑劳务费发票有进项抵扣吗
  • php xdebug配置
  • 前端实际开发
  • FPN细节剖析以及pytorch代码实现
  • js正则用法
  • vue数据加载完成显示页面过渡动画
  • 免税农业企业所得税怎样填报
  • 现金和现金等价物包括哪些
  • 缴纳税款滞纳金怎么算
  • 房地产企业的开发成本和开发费用有什么区
  • 企业增值税的税收优惠有哪些
  • Mysql数据库查询客户端
  • 教大家8天学通MongoDB——第一天 基础入门篇
  • 合营企业和联营企业构成关联方吗
  • mysql怎么替换某个值
  • sql中的聚合函数
  • 支付境外货款需要缴纳哪些税费
  • 小规模纳税人采购需要发票吗
  • 存量资金会计处理办法
  • 滴滴打车老板起源故事
  • 小规模红冲发票怎么做分录
  • 公司收到个人转账收入
  • 公司法人转账到公司账户
  • 房地产企业的会计核算
  • 汽车三产件
  • 工程发票入账
  • 未开票收入如何申报增值税
  • 生产型企业加计扣除10%
  • 工业企业应通过其他应付款科目核算的有
  • macbookair切换桌面
  • 受限怎么解除
  • Win10系统如何开启全部权限
  • centos内存占用进程
  • centos5.8服务器
  • 笔记本搜索功能用不了
  • 各种linux系统比较
  • windows8ip地址怎么设置
  • react either
  • 批处理/s
  • 批处理命令在哪个菜单中
  • node.js使用方法
  • js数组如何定义
  • java语言基于对象
  • js轮播图视频教程
  • jquery下拉列表框
  • 什么叫开源库
  • 重庆税务电子税务
  • 企业自己开的增值发票
  • 广东省地税局局长 吴
  • 黑龙江省税务局领导最新分工
  • 异地预缴增值税销售额是含税
  • 企业年检里的纳税是什么
  • 国税家园
  • 公寓限购是好事吗
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设