位置: 编程技术 - 正文

javascript学习笔记(九)javascript中的原型(prototype)及原型链的继承方式(javascript学习指南)

编辑:rootadmin
在使用面向对象编程时,对象间的继承关系自然少不了!而原型正是实现javascript继承的很重要的一种方法! 我们首先来看以下代码: 从运行的结果我们可以看出,通过关键字new创建的zhangchen这个对象继承了person中通过原型定义的getInfo()方法。下面我们具体来看新建的zhangchen这个对象是如何继承person对象的属性和方法的。 原型:在使用 JavaScript 的面向对象编程中,原型对象是个核心概念。在 JavaScript 中对象是作为现有示例(即原型)对象的副本而创建的,该名称就来自于这一概念。此原型对象的任何属性和方法都将显示为从原型的构造函数创建的对象的属性和方法。可以说,这些对象从其原型继承了属性和方法。当创建zhangchen对象时:

zhangchen 所引用的对象将从它的原型继承属性和方法,对象 zhangchen 的原型来自构造函数(在这里是函数 person)的属性。

在 JavaScript 中,每个函数都有名为prototype的属性,用于引用原型对象。此原型对象又有名为constructor的属性,它反过来引用函数本身。这是一种循环引用, 下图更好地说明了这种循环关系。

推荐整理分享javascript学习笔记(九)javascript中的原型(prototype)及原型链的继承方式(javascript学习指南),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:javascript要怎么学,javascript教程完整版,javascript入门教程,javascript入门教程,javascript如何学,javascript基础笔记,javascript入门教程,javascript基础笔记,内容如对您有帮助,希望把文章链接给更多的朋友!

图1 循环关系

现在,通过new运算符用函数(上面示例中为 person)创建对象时,所获得的对象将继承 person.prototype 的属性。在上图,可以看到 person.prototype 对象有一个回指 person 函数的构造函数属性。这样,每个 person对象(从 person.prototype 继承而来)都有一个回指 person 函数的构造函数属性。

javascript学习笔记(九)javascript中的原型(prototype)及原型链的继承方式(javascript学习指南)

我们可以用以下代码来验证这种循环是否正确:以上代码中的对"isPrototypeOf()"方法的调用来自哪里呢?是来自person.prototype对象吗?不对,实际上,在 person.prototype 和 person 实例中还可以调用其他方法,比如 toString、toLocaleString 和 valueOf,但它们都不来自 person.prototype。而是来自于JavaScript 中的 Object.prototype ,它是所有原型的最终基础原型。(Object.prototype 的原型是 null。) 在以上例中,zhangchen.prototype 是对象。它是通过调用 Object 构造函数创建的(尽管它不可见)相当于执行子以下代码:

因此,正如 person实例继承person.prototype 一样,zhangchen.prototype 继承 Object.prototype。这使得所有 zhangchen 实例也继承了 Object.prototype 的方法和属性。

原型链:每个 JavaScript 对象都继承一个原型链,而所有原型都终止于 Object.prototype。注意,这种继承是活动对象之间的继承。它不同于继承的常见概念,后者是指在声明类时类之间的发生的继承。因此,JavaScript 继承动态性更强。它使用简单算法实现这一点,如下所示:当您尝试访问对象的属性/方法时,JavaScript 将检查该属性/方法是否是在该对象中定义的。如果不是,则检查对象的原型。如果还不是,则检查该对象的原型的原型,如此继续,一直检查到 Object.prototype。下图说明了此解析过程:

图2 toString()方法的解析过程

从以上解析过程中,如果在对象中定义了属性/方法 X,则该对象的原型中将隐藏同名的属性/方法。例如,通过在 person.prototype 中定义 toString 方法,可以改写 Object.prototype 的 toString 方法。

再看以下代码:从运行结果可以看到,虽然person的每个实例都继承了person.prototype中的方法,但是我们也可以在实例化的对象中重新定义原型对象中的方法,而且也不会影响到其它的实例! 以上是自己对原型及原型链继承方式的认识,参考( JavaScript: 使用面向对象的技术创建高级 Web 应用程序),希望大家共同讨论!

actionscript与javascript的区别 当时Netscape的JavaScript使其在与ie的浏览器大战中独占鳌头,而后ie创建了jscript应对Netscape的JavaScript,而事实上jscript基本上抄袭的JavaScript,这也是微软一

js的一些常用方法小结 Val(),append(),get(),split(),substr(),each(),html(),keyup(),trim(),show(),hide(),indexOf()一个一个来看:Val():来对一个页面元素进行取值和赋值取值:varresult=$(#txtSearch).val

javascript开发技术大全-第1章javascript概述 1.1略1.2版本。略1.3javascript与浏览器略1.4javascript作用摘自《3Cschool》JavaScript能做什么?JavaScript为HTML设计师提供了一种编程工具HTML创作者往往都不是程

标签: javascript学习指南

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

上一篇:javascript 学习笔记(八)javascript对象(javascript教程完整版)

下一篇:actionscript与javascript的区别

  • 从农民手中收购粮食如何计算进项税
  • 增值税税控系统技术维护费
  • 奖励旅游的概念解释
  • 销售扣款怎么开票
  • 所得税费用会影响营业利润吗
  • 固定资产清理费用计入哪里
  • 上年少计提工会经费本年怎么调整
  • 个体工商户生产经营所得税税率表2021
  • 运输费全额抵扣什么意思
  • 技术服务费入账
  • 2019年1月份到现在几个月了
  • 公司销售固定资产汽车如何填申报表
  • 劳保费属于什么会计科目
  • 外商投资企业的组织形式,组织机构
  • 企业如何加强应收账款的管理
  • 发票如何保存
  • 购入资产的入账价格一般是以该项资产的什么反应
  • 分包工程款税率
  • 委托加工合同如何标注多个地址
  • 增值税专用发票抵扣期限
  • 担保扶持基金可以冲代偿吗
  • 增值税专用发票的税率是多少啊
  • 小规模手撕发票申报填在哪
  • 金税四期查到了怎么办
  • 借条的标准格式 手写学生
  • 出卖固定资产企业处罚
  • 银行电子承兑到期了怎么兑现操作
  • 企业自建自用房的规定
  • 对数组描述正确的是
  • 阿尔卑斯旱獭冬眠
  • php转换成html
  • php限制登录次数
  • 银行转账手续费最高多少钱
  • vue set-cookie
  • php抓取网页图片
  • web前端开发期末试题及答案
  • thinkphp yii
  • php 计算
  • userpasswords
  • 企业小微企业贷逾期起诉法人房子会被拍卖吗?
  • 纳税人兼营不同税率
  • 临时工工资无发票可以扣除吗
  • 当月确认收入可以下月确认成本吗
  • 更正申报多交的增值税查账么
  • 小企业会计准则适用于哪些企业
  • 企业所得税计提金额怎么算
  • SQL Server 2005 模板参数使用说明
  • 关于种植养殖的手抄报
  • 汇算清缴银行手续费放哪里
  • 公租房特许经营权转让
  • 应交税费应交增值税进项税额在借方
  • 暂估入库已结转成本,下月票回来,还用红冲吗
  • 政府给的专款专用的补贴需要交税吗
  • 酒店支付模式
  • 从公司账户转给他人私户1万元以内需要扣多钱的税
  • 出资注意事项有哪些内容
  • 销售方开红字发票需要什么信息
  • 借款利息如何记账
  • 在建工程不做了发生的费用如何做账?
  • 土地增值税怎么预交税款
  • 总公司是否可以注销分公司
  • 分支机构是否需要设立账簿
  • sqlserver2005网络配置里没有东西
  • linux系统啥样
  • 在xp系统中设置u盘启动
  • 苹果mac电脑不会关机
  • win10 mobile 1709
  • nginx sbin目录
  • Unity3D游戏开发培训课程大纲
  • 用来检测程序小错误的测试方法
  • cmd命令基础
  • shell数组遍历
  • Tasharen Fog of War v1.0战争迷雾插件的使用(含Unity5.0Bug解决)
  • 工具类别怎么填写
  • 全年上缴个人所得税多少
  • 补充协议需要双方签字盖章吗
  • 医保漏缴如何补交
  • 公司账户注销了,是不是网银也注销了
  • 税务局风险防控工作总结
  • 税务筹划和纳税申报哪个更容易学
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设