位置: 编程技术 - 正文

举例说明JavaScript中的实例对象与原型对象(举例说明Java实现适配器模式)

编辑:rootadmin

推荐整理分享举例说明JavaScript中的实例对象与原型对象(举例说明Java实现适配器模式),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:举例说明的作用,举例说明Java实现适配器模式,举例说明Java实现适配器模式,举例说明Java实现适配器模式,举例说明Java实现适配器模式,举例说明Java实现适配器模式,举例说明javascript中字符串转换为整数和浮点数,举例说明javascript常量与变量,内容如对您有帮助,希望把文章链接给更多的朋友!

首先声明:javascript中每个对象都有一个constructor属性和一个prototype属性。constructor指向对象的构造函数,prototype指向使用构造函数创建的对象实例的原型对象。

在这段代码中会报错,sayName() is not defined。根据javascript高级程序设计第二版的解释,是因为重写的原型切断了构造函数与最初原型之间的联系。但是我们调整一下上面语句的顺序。如下:

注意上面两段代码等号中间的语句。按第二段的顺序写代码,将会输出 ”zxs“,这个结果说明在第一种情况下报错并不能说明是因为切断了构造函数与原想之间的联系引起的。

本来就是一种定义对象的方法,而且在javascript中每个对象的constructor属性都默认的指向Object构造函数,这也就不难说明重写原型对象确实切断了构造函数与最初原型之间的联系,但并不能说明这种联系被切断之后 person就不能访问到sayName()函数。

现在有这样的假设:函数的prototype属性所指向的原型对象,与我们显示新建的原型对象并不是完全等同的。当我们调用函数的时候会创建一个原型对象,此时会首先查找当前环境中是否存在其原型对象,如果程序中不存在,就创建一个,如果环境中存在,侧查找他们的属性和方法,最后根据查找的结果返回一个原型对象,这个对象中的属性和方法总是优先使用默认原型中的属性和方法,也就是构造函数中定义的属性和方法。当当调用的方法或属性不存在于默认的原型中时,才使用定义在Person.prototype = {} 的属性和方法。

javascript是解释性的语言,语句都是顺序执行的,在第一段代码中,当我们使用 new 关键字创建新对象的时候,Person.prototype = {} 并没有执行,也就是说在当前的执行环境中找不到其中定义的方法和属性,而构造函数中没有该方法,所以出错。就像一个变量,给他赋值的时候程序没有执行将不能使用。在第二段中环境中已经存在该调用的方法,构造函数的原型对象已经创建完毕,所以可以得到结果。

举例说明JavaScript中的实例对象与原型对象(举例说明Java实现适配器模式)

再看下面的一段程序:

从这里可以看出使用 Person.prototype.name = '',的方式不论在什么地方创建对象都能被访问,如果同时存在对象字面量和这种方法定义原型对象,将使用后定义的作为最终值。并且对原型对象使用对象字面量定义之后,该定义必须出现在创建对象的语句之前才能被访问到。

实例不能访问到原型对象中的属性和方法,不仅仅是因为重写原型对象切断了构造函数与最初原型之间的联系。

以上代码在实例化对象时构造函数的原型为空,它没有任何除默认属性以外的属性。重写构造函数的原型确实切断了构造函数与最初原型之间的联系。

在使用 new 操作符以后构造函数的原型对象中的属性和方法已经添加到 person对象中。因为以上方法为函数原型添加新属性和方法不具有动态性,所以person不能访问到新添加的属性和方法。

重写原型对象之后,就如同如下代码:

此时输出的值是undefined,因为,对象是一个引用类型,“=”是赋值操作符,并且其运算顺序是从右往左。o={}就是说o的指向已经改变,是一个空对象。Person.prototype.mothed = function() {}与Person.prototype={mothed:function(){}}的区别就如同 arr = []和arr.push()一样,前者都是修改自身,后者是完全改变自身。

JavaScript操作HTML DOM节点的基础教程 因为DOM的存在,这使我们可以通过JavaScript来获取、创建、修改、或删除节点。NOTE:下面提供的例子中的element均为元素节点。获取节点父子关系element.par

JavaScript中循环遍历Array与Map的方法小结 js循环数组各种方法eg1:for(vari=0;imyStringArray.length;i++){alert(myStringArray[i]);//Dosomething}eg2:Array.prototype.foo="foo!";vararray=['a','b','c'];for(variinarray){alert(array[i]);}fo

详解JavaScript中数组和字符串的lastIndexOf()方法使用 Array.prototype.lastIndexOf和String.prototype.lastIndexOf是非常的实用的方法,不过很多人不知道它其实可以传递两个参数,第二个参数决定了搜索的起始位置:语

标签: 举例说明Java实现适配器模式

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

上一篇:javascript中call apply 与 bind方法详解

下一篇:JavaScript操作HTML DOM节点的基础教程(js+html)

  • 租集体土地建厂合法吗
  • 劳务公司发放农民工工资要开发票吗?
  • 行政事业性收据发票记帐
  • 什么是免税合并
  • 发票号码不一致可以报销吗
  • 营业外收入是否属于当期损益
  • 资产负债表中未交税金负数表示什么
  • 在建工程转入固定资产当月计提折旧吗
  • 半年度奖金怎么算
  • 刚成立的外贸公司做小规模纳税人好不好
  • 外购自用需要缴纳增值税吗
  • 销售出库发票会计分录怎么做?
  • 临时工人工资原始凭证怎么做及会计分录解析?
  • 承包外单位食堂会计怎么做账
  • 税务稽查补缴的税款怎么处理
  • 零售通收银
  • 合同无效后还能主张违约责任吗
  • 六税两费减半征收政策2022
  • 小规模纳税人需要汇算清缴吗
  • 固定资产用于免税项目 进项税处理
  • 端午节给员工发福利说什么
  • 软件产品登记证书官费
  • 申请增值税一般计税方法的个体工商户可自
  • 利润弥补亏损如何处理
  • 无法访问移动网络怎么办
  • 单位租房的房租怎么入账
  • macOS Catalina10.15.2值得升级吗 macOS Catalina10.15.2更新了什么
  • win10wifi老是自动断开怎么回事
  • php数组函数,选班长
  • 简单介绍下商务洽谈的五个步骤
  • 商品从总仓到分拣要多久
  • 存货短缺的账务处理
  • 进价金额核算法的账务处理特点
  • php使用crypt()函数进行加密
  • 土地使用税缴纳人是使用者还是所有权人
  • flex布局使用
  • 发行股票的手续费佣金计入什么科目
  • php匿名函数为何不匿名
  • ab计数器指令程序
  • php的框架有哪些
  • 创建vue3项目的步骤
  • php教程从入门到精通
  • 建筑安装包清工税率多少
  • 保险费的增值税税率
  • 购买股权溢价部分怎么做账
  • dedecms51
  • rbac权限管理设计
  • 财政总预算会计的特点
  • 工业企业增值税税负多少合理
  • 受托方代收代缴的消费税应计入什么科目
  • 更正申报失败,维持原申报?
  • 报表中的存货是什么
  • 资产负债表调整事项
  • 营改增后个人所得税计税依据实例
  • 主营业务成本工资写什么部门
  • 两个公司之间怎么走账
  • 调整以前年度利息支出
  • 开具的增值税专用发票上注明的价款含税吗
  • 长期待摊费用处置
  • 现金日记账与现金流量表的区别
  • 公司的应付账款
  • 要建立linux分区可以有哪几种方法
  • docker 自启动
  • FNPLicensingService.exe是什么意思
  • mission controller
  • win1020h2版好不好
  • 在linux系统中有一个重要的概念
  • jquery提交form表单数据
  • listary 替代
  • javascript如何绘制曲线
  • python 递归函数与循环的区别
  • unity androidx
  • javascript定律
  • js中concat的用法
  • Landroid/support/v7/internal/widget/ActionBarOverlayLayout;.stopNestedScroll
  • js调用声音
  • 企业所得税季报资产总额怎么填
  • 税务监察室具体工作内容
  • 新疆中国邮政投诉电话
  • 重庆路桥价值
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设