位置: 编程技术 - 正文

学习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四种图片样式

  • 社保缴费基数怎么算出来的啊
  • 公司为员工报销的医药费
  • 企业捐赠灾区
  • 资本公积可以随时撤出来吗
  • 营业收入少入0.02怎么办
  • 结转应交所得税属于利润分配吗
  • 外资企业解释
  • 银行结算方式包括哪些内容
  • 其他应收款通俗
  • 个人开具建筑服务发票
  • 企业发工资哪些需要缴个人所得税?
  • 过渡费交税吗
  • 自产自销农产品企业所得税
  • 普通发票税率为1%吗
  • 开票税率选错申报增值税时怎么处理
  • 年终奖个税公式 2022
  • 维修费属于印花税
  • 暂估入账冲回
  • 网络限速数值
  • 政府补助退回的账务处理
  • abm文件怎么打开
  • 自由职业者如何交五险一金
  • 业务招待费的纳税筹划
  • 工程未审计资金能支付到多少
  • 基于springboot的毕设
  • 红字发票账务处理需冲回成本吗?
  • chrome浏览器清除数据
  • php socket_create
  • php引用传值
  • 市职工报销比例多少
  • Pytorch深度学习实战3-6:详解网络骨架模块nn.Module(附实例)
  • 基于vue的ui
  • 现金日记账每月都做本年累计数吗?
  • 房产税缴纳时间点
  • 购进原材料款项未付应编制什么凭证
  • 绿化苗木抵扣税是多少
  • 物业管理可以开保洁发票吗
  • 上个月发票税率怎么查
  • 核销发生的坏账损失
  • 帝国cms使用手册
  • sql将一列数据变成一行显示
  • 给客户买的车票怎么查询
  • 吃饭的票如何写报销单
  • 2021新旧会计准则的比较分析
  • 使用sql server查询不到会返回什么
  • SqlServer中用exec处理sql字符串中含有变量的小例子
  • 一般纳税人不开票收入怎么做账
  • 长期资产的减值会影响CFO吗
  • 体检费用需要缴哪些费用
  • 主要业务活动是什么意思
  • 一般纳税人条件要求2020
  • 利润分配未分配利润是净利润吗
  • 上下班出车祸公司怎么赔偿
  • 工作服入什么科目类别
  • 应收贷方余额表示什么意思
  • 汇算清缴步骤及处理方法
  • 本年利润在明细里怎么填
  • 互联网金融理财产品的优势
  • 企业叉车折旧年限几年
  • 小额零星支出是什么意思
  • 企业办理增资的程序
  • 账务不实与账实不符
  • mysql连接查询和子查询效率
  • xp系统浏览器收藏夹文件位置
  • linux开机启动ftp
  • mac连电视
  • linux运维常用命令汇总
  • linux怎么使用
  • 怎么在linux中安装软件
  • jquery实现
  • shell脚本语句
  • 关于javascript事件响应的基础语法总结(必看篇)
  • cmd nul
  • javascript中的107个基础知识收集整理 推荐
  • html dom元素
  • python 命令
  • python flask
  • 安徽省低保查询入口官网
  • 贷款利息收入增值税税率2023
  • 国税局招录条件
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设