位置: 编程技术 - 正文

JavaScript 原型与继承说明(简述javascript原型和原型链有什么特点?)

编辑:rootadmin
function A(x) { this.x = x; } alert(A.prototype); alert(A.prototype.constructor); 根据弹出的结果,我们可以得到:原型对象是由函数的构造函数创建,它所拥有的属性能被所有对象共享,初始时原型对象指向一个Object对象,并且定义了一个constructor属性,该属性指向定义该原型对象的构造函数本身,再看如下代码。 Code function A(x) { A.prototype.x = x; } var obj = new A(); alert(obj.x); alert(obj.constructor); 因为原型对象的所有属性能被构造函数创建对象共享,所以创建的对象可以访问这里的constructor属性,同时obj对应的就是原型对象(prototype)所创建出来的一个实例,那么重写constructor属性会出现什么样的结果呢? Code function A(x) { A.prototype.x = x; } var objA = new A(); objA.constructor = function(x){ alert("重写obj的constructor属性");this.x = }; objA.constructor(); alert(objA.x); var objB = new A(); alert(objB.x); 根据结果我们可以看到,首先弹出的是“重写obj的constructor属性”,然后弹出,在弹出,可见,我们在书写重写objA这个对象的constructor之后,objB并没有被改变,因此无论在一个对象加入或修改多少属性这都不影响其原型对象中属性的本来面目,其实很容易理解js为什么这样做,因为一个对象的行为不能影响到其他对象,否则将会造成混乱。 在这里,我们可以总结一下,上面代码的规则: 1.当我们调用某个对象的时候,首先检查该对象本身的自己定义的属性,如果存在则调用。 2.当自己本身的属性不存在的时候,则调用其构造函数所定义的原型对象的引用。 那么根据这个规则,就形成了JavaScript中的一个原型链,我们就可以根据这个规则来定义继承关系。 这段代码显示了两个函数,B函数继承与A函数,A.call(this.x)表示,将B的对象this传递到A函数中进行执行。然后,我们同样需要由B函数构造出来的对象需要包含A函数的所有特性,因此需要加上这么一句话。 先我们指定B的原型为A,因此,B函数继承了A函数的特性,根据弹出的结果,我们可以看到,其constructor指向的是A函数,那么我们的B函数的特性是不是丢失了呢?因此,我们需要在加上一句话,最后给出继续的整合代码。 若有疑问或不正之处,欢迎提出指正和讨论。

推荐整理分享JavaScript 原型与继承说明(简述javascript原型和原型链有什么特点?),希望有所帮助,仅作参考,欢迎阅读内容。

JavaScript 原型与继承说明(简述javascript原型和原型链有什么特点?)

文章相关热门搜索词:js原型constructor,js的原型对象,javascript中的原型和原型链,简述javascript原型和原型链有什么特点?,js原型作用,javascript原型和原型链特点,javascript原型和原型链特点,javascript中的原型和原型链,内容如对您有帮助,希望把文章链接给更多的朋友!

JavaScript的单例模式 (singleton in Javascript) 单例模式的基本结构:MyNamespace.Singleton=function(){return{};}();比如:MyNamespace.Singleton=(function(){return{//Publicmembers.publicAttribute1:true,publicAttribute2:,publicMethod1:fu

JavaScript接口实现代码 (Interfaces In JavaScript) 在实际中,我们可以在注释中定义好接口,在实际的代码中予以实现比如:/*interfaceComposite{functionadd(child);functionremove(child);functiongetChild(index);}interfaceFormI

javascript面向对象编程(一) 实例代码 scripttype="text/javascript"vartest={numA:,objB:{},arrC:[],init:function(){alert(this.numA);},sayHi:function(name){alert("hello"+name);},sayHelloWorld:function(){this.sayHi("world");},get:function()

标签: 简述javascript原型和原型链有什么特点?

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

上一篇:JavaScript 构造函数 面相对象学习必备知识(javascript构造函数创建对象)

下一篇:JavaScript的单例模式 (singleton in Javascript)(js编写一个标准的单例模式类)

  • 预缴增值税是否要预缴企业所得税
  • 读懂增值税
  • 环保税征税
  • 印花税申报缴纳错误,怎么办
  • 城建税的计税依据是增值税和消费税的和吗
  • 运输开票的税点是多少
  • 企业给员工的福利取消了可以劳动仲裁么
  • 外管证过期了一个月罚款多少
  • 结构性存款是
  • 个人交的社保发票怎么开
  • 同一控制吸收合并会计处理
  • 律师事务所日常管理松懈混乱整改措施
  • 资本公积转实收资本会计科目
  • 个人独资企业可以不开公户吗
  • 预收账款开票可以抵扣吗
  • 股东转让股份怎么转让
  • 本月收到外汇怎么做账
  • 环评公司的成本核算
  • 税务机关核定征收契税
  • 融资租入的固定资产视为承租企业的资产体现了什么原则
  • 仓储费怎么账务处理
  • 打车进项可以抵扣吗
  • 企业支付工商年费怎么查
  • 2021年6月更新
  • 出口退税的条件包括
  • php获取访问者qq
  • php调用外部接口
  • 弥补亏损需要注意的事项
  • 存货周转率公式怎么算
  • 消费税不可抵扣已纳税款
  • 以太网默认网关不可用
  • 最大交易笔数什么意思
  • 职工教育经费列支范围规定
  • 关联方借款利息所得税前扣除
  • 年末结转利润分配账户的借方余额表示
  • php time
  • 外购商品转为自用洧费税计算
  • laravel框架中文手册
  • 来料加工企业转型是转成两个企业吗
  • php ascii
  • thinkphp教程
  • Vue3 中 createWebHistory 和 createWebHashHistory 的区别
  • 债权投资 科目
  • 预训练的目的
  • thinkphp excel
  • 人工智能导论课后题答案
  • 模式识别与图像处理能做什么
  • x-s和web_session
  • php第三方支付
  • 新成立的公司怎么算生育津贴
  • 注解注入
  • 金蝶固定资产折旧调整
  • 个人独资企业应税生产经营所得可以扣除税金支付
  • 会计政策变更追溯调整的年限
  • 公司购买股票会计分录怎么做
  • 现金解款单的会计分录
  • 材料成本差异会计处理
  • 仓库到仓库贸易术语
  • 业务招待费扣除标准是多少
  • 电子发票报销需要在背后签名吗?
  • 以前年度损益调整属于哪类科目
  • 开发票系统税号0和o怎么区别?
  • 专票取消认证
  • 仲裁是什么意思举个例子
  • vc6运行程序
  • ubuntu tcp
  • hc off line什么意思
  • win8系统怎么样
  • win7开机出现两个系统选项
  • win7系统如何屏幕放满屏幕
  • unity开发3a
  • Zen Coding css,html缩写替换大观 快速写出html,css
  • python简单加密
  • c++ 编程
  • javascript基础入门视频教程
  • 基于bootstrap的网站
  • js框架开发实例
  • 不同地区的社保卡通用吗
  • 什么车属于应征消费税的汽车
  • 教育培训行业的前景
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设