位置: 编程技术 - 正文

学习JavaScript设计模式(继承)(javascript怎么学)

编辑:rootadmin

推荐整理分享学习JavaScript设计模式(继承)(javascript怎么学),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:javascript如何学,javascript教程chm,javascript设计,javascript设计,javascript教程chm,javascript教程chm,javascript课设,javascript设计,内容如对您有帮助,希望把文章链接给更多的朋友!

1、继承

在javascript中继承是一个非常复杂的话题,比其他任何面向对象语言的中的继承都复杂得多。在大多数其他面向对象语言中,继承一个类只需要使用一个关键字即可。与它们不同,在javascript中要想达到传承公用成员的目的,需要采取一系列措施。更有甚者,javascript属于使用原型式继承的少数语言之一。利益于这种语言的灵活性,你既可使用标准的基于类的继承,也可使用更微妙一些的原型式继承。

2、为什么需要继承&#;

一般来说,在设计类的时候,我们希望能减少重复性的代码,并且尽量弱化对象间的耦合。使用继承符合前一个设计原则的需要。借助这种机制,你可以在现有类的基础上进行设计并充分利用它们已经具备的各种方法,而对设计进行修改也更为轻松。假设你需要让几个类都拥有一个按特定方式输出类结构的toString()方法,当然可以用复制加粘贴的办法把定义toString()方法的代码添加到每一个类中,但这样做的话,每当需要改变这个方法的工作方式时,你将不得不在每一个类中重复同样的修改。反之,如果你提供了一个ToStringProvider类,然后让那些类继承这个类,那么toString这个方法只需在一个地方声明即可。

让一个类继承另一个类可能会导致二者产生强耦合,也即一个类的依赖于另一个类的内部实现。我们将讨论一些有助于避免这种问题的技术,其中包括用掺元类为其他类提供方法这种技术。

3、基于类的继承

下面看下面的代码:

输出结果: 张三 , 可以看到Student成功集成了Person,并且拥有了Person的say方法,核心代码其实就是一句 Student.prototype = new Person();,下面通过图解来说明原理:

学习JavaScript设计模式(继承)(javascript怎么学)

将Student.prototype指向new Person() , new Person的_proto_又指向Person Prototype;这样完成了整个继承。

但是这种方式存在问题:

问题1:当父类存在引用类型变量时,造成数据不一致,下面我们给Person添加一个hobbies属性,类型为数组。

输出结果:张三 , , soccer 李四 , , soccer,girl 可以看出,李四的hobbies应该只有girl,但是上面的代码让所有对象共享了hobbies属性。 上述的继承方式还存在一个问题:

问题2:在Student的构造方法中,无法使用new Student(“” , “张三” , ) ;创建对象,并初始化name和age属性,必须stu.name, stu.age进行赋值

为了解决上述问题,对上述代码进行修改:

输出: , 张三 , soccer , 李四 , cangjin,basketball 在Student的构造方法中使用了Person.call(this,name,age)感觉就像super(name,age)【call的第一个参数为上下文】;并且成功解决了对引用属性的共享问题,完美解决。

4、基于原型链的继承

输出:zhangsan , , Java lisi , , Java,Javascript 可以看出同样存在引用属性不一致的问题,并且整个操作全部基于对象,给人的感觉不是很好,下面通过图解解释下原理:

对象间通过一个clone函数,不断的返回一个新的对象,且prototype执行传入的对象,整个继承过程其实就是_proto_不断的指向,形成一个链,所以叫做原型链。

好了,已经介绍完了,js的两种集成的方式,最好使用的还是通过类的继承,比较稳定。

标签: javascript怎么学

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

上一篇:js图片跟随鼠标移动代码(js鼠标滚动控制图片缩放)

下一篇:学习JavaScript设计模式(链式调用)(javascript教程chm)

  • 跨年度调整税金及附加
  • 房产等价置换是否需要缴纳契税?
  • 哪些产品享受教育优惠
  • 个人所得税有哪些减免政策
  • 出售无形资产属于资产处置损益吗
  • 销户本金转入保单怎么办
  • 进口发票可以抵扣吗
  • 工会经费申报晚了怎么处理
  • 专票当普票用,发票勾选怎么操作
  • 一般纳税人收入会计分录
  • 企业资产折旧抵扣所得税
  • 企业管理咨询有限公司简介
  • 会计发票怎么样粘贴,记账凭证也要粘上吗
  • 在建工程工伤保险
  • 事业单位跨年度错账调整
  • 党组织专项经费项社区服务队项目简介
  • 未按期预缴企业个税
  • 销售自产自销的产品要交税吗?
  • 加速折旧做账
  • 无票收入应附什么单据
  • 广告宣传费用的计算方法
  • 手撕票验旧是什么意思
  • 购买国债逆回购有股东限制
  • 资源税改革对政治的影响
  • 个税申报已经申报如何更改
  • 无形资产的入账价值包括什么
  • 小规模印花税减免性质代码怎么填
  • 外贸企业出口退税撤销申报
  • 长期待摊费用发生当月摊还是次月摊
  • vmware虚拟机无法打开网页
  • mac安装windows不能用键盘
  • 修改远程桌面端
  • 会计基础工作是会计工作的基本环节
  • 其他生活服务业增值税税率
  • 将现金存入银行,登记银行存款日记账的依据一般是
  • 防伪码查一次还能查第二次吗
  • 建安企业账务处理 工程施工
  • php字符串的三种定义方式
  • php抽象类可以多继承吗
  • 命令行修改mbr
  • 泛化的理解
  • 办理车辆购置税流程
  • 删除python包
  • 织梦采集器图片本地化
  • 电脑自学网
  • 工会经费发放奖励个税处理
  • 发票一式两联
  • 地方教育费附加会计分录怎么做
  • 销售会计的岗位职责有哪些
  • 库存现金挂账多久
  • 财务报表漏报了会影响领票吗
  • 个人独资企业的特点
  • 行政单位拨出经费的规定
  • 确认应付职工薪酬如何计算
  • 材料折扣会计分录
  • 差旅费报销单填写模板电子版
  • 工会经费计提比例0.8%
  • 分公司做账报税
  • 主营业务收入少计跨年调整
  • 如何远程连接小米摄像头
  • mysql5.6下载
  • mysql8.0无法启动
  • winxp使用到什么时候
  • macos sierra怎么升级到big sur
  • linux中进程在运行时的基本状态
  • 使用u盘安装macos
  • ubuntu18.04安装wps
  • linux which ls
  • centos获取权限
  • ISBMgr.exe - ISBMgr是什么进程 有什么作用
  • vim删除^m
  • 修改win7
  • javascript definitive guide
  • nodejs webapp
  • jquery中的事件
  • npm安装nodemodules
  • android广播接收器数量达到1000
  • Python3的urllib.parse常用函数小结(urlencode,quote,quote_plus,unquote,unquote_plus等)
  • 用javascript
  • 挂车是否需要缴纳车船税
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设