位置: 编程技术 - 正文

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编写一个标准的单例模式类)

  • 销售收入怎么计算销项税额
  • 报废车残值款计入什么科目
  • 简述入伙、退伙的含义与退伙的形式
  • 上年结转未抵扣
  • 税金及附加没有什么税
  • 废料账务处理
  • 化肥贸易需要什么手续
  • 营改增后向境外提供有偿服务是否需要缴纳增值税?
  • 个人名义帮公司贷款
  • 企业购车票可以抵扣增值税吗?
  • 进项税额转出报税填哪个表
  • 发票的金额可以答应客户多开
  • 物业服务费属于什么合同印花税
  • 小规模820如何填写申报表?
  • 广告发布税收编码
  • 收入冲正
  • 股东私人垫支公司支付零星材料的会计分录
  • 初级会计备课指点
  • 记账凭证保存年限2019
  • 资本公积的借方和贷方各表示什么
  • 福利费计提包括奖金吗
  • 补缴纳以前年度企业所得税税率如何论定
  • 投入的生产线应该怎么做
  • explorer.exe进程文件
  • 汇票本票支票的相同点和不同点
  • win7纯净版系统怎么安装
  • ElementPlus DateTimePicker日期时间选择器限制可选时间范围(精确时分秒)
  • 元素鼠标失灵了怎么办
  • 超像素和markpage的区别
  • nerf新手入门
  • Yii2创建多界面主题(Theme)的方法
  • 帝国cms app
  • 插件不支持是什么意思
  • 公司内部现金管理制度
  • mysql有什么优势和特点
  • mysql需要转义的特殊字符
  • 固定资产进项税额怎么抵扣
  • 运输服务的增值税税率到底是6还是9
  • sql多条记录取一条
  • PostgreSQL 角色与用户管理介绍
  • 企业出售房屋
  • 主办会计的工作内容和职责
  • 科目余额表如何看
  • 建筑施工企业检查的内容包括什么
  • 增值税期末留抵退税什么意思
  • 单据 凭证
  • 现金零星金额多少
  • 带息票据与不带息票据
  • 三证合一是哪三证
  • 专项附加扣除项目
  • 海关进口代理公司名称
  • 内账外账用一个云盘可以吗
  • 营改增后工程项目计价规则也随之发生了改变对还是错
  • 会计主体包括哪些四种
  • 私营公司固定资产怎么查
  • sqlserver中with(nolock)深入分析
  • win10系统怎么隐藏c盘
  • win8系统升级
  • xp sp3精简版
  • windows wps
  • win7如何设置网络连接路由器
  • 炉石传说开发人员卡牌
  • JavaScript数组去重
  • 列举javascript中的所有数据类型
  • 前端html中怎么让文字左移
  • jquery 多选
  • andengine学习,《android游戏开发实践指南》详解
  • node.js教学
  • python 二叉树
  • vue组件精讲
  • python ip地址转换
  • js 正则replace
  • nodejs处理excel
  • 带领大家学习javascript基础篇(一)之基本概念
  • jquery鼠标悬停显示内容
  • javascript的介绍
  • ajax获取数据两种类型
  • 乡镇经管站是如何工作
  • 杭州金税盘客服电话是多少
  • 电影失眠详细剧情
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设