位置: 编程技术 - 正文

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

  • 外商投资合伙企业法
  • 所得税月度申报
  • 什么叫关税完税价
  • 国际反避税措施
  • 减资 股东
  • 申报无票收入次月红冲有没有风险
  • 企业结算时待摊费用怎么办
  • 一般纳税人简易计税可以抵扣进项税额吗
  • 开票方丢失记账怎么处理
  • 公司废品处理一定要入账吗
  • 运费的进项税
  • 商会会费是什么意思
  • 应税销售行为的购买方为消费者个人的可以开专票吗
  • 农村电网维护费会计分录
  • 房地产企业预售阶段企业所得税
  • 企业库存现金的限额是由( )核定的
  • 企业弥补亏损的三个途径
  • 企业租入固定资产发生的改良支出计入什么科目
  • 投标保证金以现金的形式缴纳,能以现金的形式退回吗
  • 分公司注销所得税
  • 公司给员工的商业保险
  • 水利行政事业性收费收入会计分录
  • 小微企业免征增值税申报表怎样填
  • 小规模纳税人贷款利息收入增值税税率
  • 水资源税计入会计科目
  • 建筑包工包料是包哪些
  • 企业已交地税税金如何做账务处理?
  • 小规模纳税企业所得税优惠政策
  • 固定资产折旧计提时间
  • 收到材料未收到会计处理
  • win10专业版用户名和密码怎么取消
  • 员工出差火车票可以抵扣进项吗
  • 电脑刷新率怎么调低
  • 回迁房办理房产证契税怎么交
  • 权重值的确定可以依据什么
  • 第三方代收的款项是什么意思
  • 基于个人同意处理个人信息的个人什么撤回其同意
  • Vue3通透教程【十二】TS类型声明优势
  • pythonsorted函数的作用
  • sqlserver2008实例配置
  • 房租收入如何纳税
  • 企业当期营业收入的计算
  • 其他综合收益算当期损益吗
  • 利息收入填在汇算清缴哪里
  • 建筑公司跨区域经营预缴
  • 创投收入
  • 政府补助收入总额法会计分录
  • 支付上月采购货款
  • 进项税转出怎样做账务处理
  • 汇算清缴前取得发票可以税前扣除吗
  • 先开收据再打款
  • 代收通行费不征税吗
  • 车辆租赁费发票怎么开
  • 产品成本核算有多条原则和要求
  • mysql删除重复的id但各保留一个
  • w10预览版新功能
  • XP系统怎么调节屏幕亮度
  • VirtualBox虚拟机中文免费
  • ikeeperpab.exe是什么
  • ubuntu系统查看mac地址命令
  • fan.error是什么意思
  • centos6.5怎么进入图形界面
  • win8系统如何卸载软件
  • win8电脑远程控制怎么弄
  • opengl文档窗口是什么
  • css如何设置div位置
  • dos 判断
  • iframe内容自适应缩放
  • Node.js中child_process实现多进程
  • vue.js打包部署
  • 浅谈jquery中next与siblings的区别
  • unity androidx
  • jquery轮播代码
  • javascript要怎么学
  • jQuery插件扩展extend的简单实现原理
  • jquery显示隐藏div
  • 银行代扣流程
  • 调查问卷的背景资料怎么写
  • 外地人在上海奉贤区买房需要什么条件
  • 开票系统ukey抄报税
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设