位置: 编程技术 - 正文

javascript学习小结之prototype(小白学javascript)

编辑:rootadmin

推荐整理分享javascript学习小结之prototype(小白学javascript),希望有所帮助,仅作参考,欢迎阅读内容。

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

JS中的prototype是JS中比较难理解的一个部分

本文基于下面几个知识点:

1 原型法设计模式在.Net中可以使用clone()来实现原型法

原型法的主要思想是,现在有1个类A,我想要创建一个类B,这个类是以A为原型的,并且能进行扩展。我们称B的原型为A。

2 javascript的方法可以分为三类:a -> 类方法

b -> 对象方法

c -> 原型方法

例子:

3. obj1.func.call(obj)方法意思是将obj看成obj1,调用func方法,本来调用的是obj1的func方法,但是,传入obj后,改变了上下文对象,就通过obj对象来调用ojb1的方法了

好了,下面一个一个问题解决:

prototype是什么含义?

javascript中的每个对象都有prototype属性,Javascript中对象的prototype属性的解释是:返回对象类型原型的引用。

javascript学习小结之prototype(小白学javascript)

A.prototype = new B();

理解prototype不应把它和继承混淆。A的prototype为B的一个实例,可以理解A将B中的方法和属性全部克隆了一遍。A能使用B的方法和属性。这里强调的是克隆而不是继承。可以出现这种情况:A的prototype是B的实例,同时B的prototype也是A的实例。

先看一个实验的例子:

我们首先定义了baseClass类,然后我们要定义extentClass,但是我们打算以baseClass的一个实例为原型,来克隆的extendClass也同时包含showMsg这个对象方法。

extendClass.prototype = new baseClass()就可以阅读为:extendClass是以baseClass的一个实例为原型克隆创建的。

那么就会有一个问题,如果extendClass中本身包含有一个与baseClass的方法同名的方法会怎么样?

下面是扩展实验2:

实验证明:函数运行时会先去本体的函数中去找,如果找到则运行,找不到则去prototype中寻找函数。或者可以理解为prototype不会克隆同名函数。

那么又会有一个新的问题:

如果我想使用extendClass的一个实例instance调用baseClass的对象方法showMsg怎么办?

答案是可以使用call:

这里的baseinstance.showMsg.call(instance);阅读为“将instance当做baseinstance来调用,调用它的对象方法showMsg”

好了,这里可能有人会问,为什么不用baseClass.showMsg.call(instance);

这就是对象方法和类方法的区别,我们想调用的是baseClass的对象方法

最后,下面这个代码如果理解清晰,那么这篇文章说的就已经理解了:

标签: 小白学javascript

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

上一篇:简单实现JS对dom操作封装(js操作dom节点的方法)

下一篇:Javascript实现检测客户端类型代码封包(javascript test)

  • 旅游公司的账务框架
  • 给个体工商户打工不发工资怎么办
  • 公司团体体检的洽谈
  • 过桥过闸通行费会计分录
  • 项目所在地预缴增值税
  • 去年的进项发票今年还能抵扣吗
  • 公司账户的钱怎么取出来
  • 税务系统有问题
  • 工程项目立项前的安全评估
  • 丢失发票罚款如何入账
  • 企业所得税季报时间
  • 股东分红利息
  • 税控盘会计处理
  • 部门奖金怎么入账
  • 员工离职后收取客户钱款
  • 境外企业提供软件使用权给境内企业
  • 发票离线限额什么意思
  • 企业所得税到底是25%还是5%
  • 小规模纳税人自开专票
  • 商誉摊销法的优缺点
  • windows 10纯净版
  • 苹果Mac系统怎么用光盘安装
  • i7 5960X评测跑分参数介绍
  • 电脑找不到休眠设置了
  • 基准收益率是
  • 出租厂房折旧可以税前扣除
  • 未分配利润转增股本交印花税
  • mpd linux
  • html无刷新跳转
  • 提坏账准备的会计分录 2022
  • 机器学习中的数据预处理方法与步骤
  • XHProf报告字段含义的解析
  • yii框架连接数据库
  • vue基础知识
  • nlp自然语言处理框架
  • pytorch csdn
  • 主营业务成本入账分录
  • 股东投资款怎么存入公司
  • 会计要离职了要注意几点
  • 公司购买电脑怎么做会计分录
  • 购进的货物含税吗
  • php数据库网址
  • 小规模没有税控怎么开普票
  • 分公司财务负责人要求
  • mysql索引之间的区别
  • 开发无形资产过程中发生的支出计入什么科目
  • 在建工程账务处理会计分录
  • 其他应收款借方表示增加吗
  • 装饰公司购入材料税额会计分录
  • 小规模增值税退税流程怎么操作
  • 工业企业制造费用具体怎么摊
  • 火车退票费如何开票
  • 国有资产无偿划转协议
  • 利息收入应该填什么科目
  • 公司采购产品赠送给客户会计分录
  • 银行贷款信用贷
  • 兼职会计如何做账报税
  • 职工薪酬包括的内容
  • 企业代理社保
  • 长期待摊费用如何做分录
  • 公司注销记账凭证还有用吗
  • 财务成本控制总结
  • 各单位应当根据需要设立专职或者兼职
  • 旅游饮食服务企业财务会计制度
  • centos6.9 yum
  • Python MySQL进行数据库表变更和查询
  • pc端直通车的位置有些?
  • xp怎么删除电脑系统
  • Win10 Mobile Build 14327上手视频评测
  • win8注销在哪里
  • apk反编译是什么意思
  • js给图片加水印
  • pythonglobal用法
  • 陕西省地方税务局公告2017年第2号
  • 电子税务局申领的发票怎么读入金税盘
  • 音箱海关税
  • 湖南省国家税务局历任局长
  • 如何查询甘肃省志愿录取状态
  • 消费税是单一环节征税吗
  • 云南省税务局召开的会议
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设