【Infragistics教程】在javascript构造函数中创建基本继承

2019独角兽企业重金招聘Python工程师标准>>> hot3.png

【下载Infragistics Ultimate最新版本】

用javascript创建对象有四种方法。具体如下:

  1. 对象作为文本
  2. 构造函数调用模式
  3. 创建()方法
  4. 在ES6之后使用类

继承的实现因对象创建方法而异。本文将解释如何在函数构造函数之间创建继承。

假设您有一个函数:

1

2

3

4

function animal(name, age) {

    this.name = name;

    this.age = age;

}

如果使用new操作符调用animal函数,将创建一个对象。这种对象创建方式也称为“构造函数调用模式”。

1

2

3

4

var dog = new animal('foo', 5);

console.log(dog);

var cat = new animal('koo', 3);

console.log(cat);

对象dog和cat都有自己的名称和年龄属性。如果希望在所有对象之间共享属性或方法,请将其添加到函数原型中。

1

2

3

4

animal.prototype.canRun = function () {

  

    console.log('yes ' this.name + ' can run !');

}

使用javascript原型链,dog和cat对象都可以访问canrun方法。

1

2

3

4

5

var dog = new animal('foo', 5);

dog.canRun(); // yes foo can run

 

var cat = new animal('koo', 3);

cat.canRun(); // yes koo can run

接下来,让我们创建另一个构造函数——人:

1

2

3

4

5

6

7

8

function human(name, age, money) {

    this.name = name ;

    this.age = age ;

    this.money = money;

}

human.prototype.canEarn = function () {

    console.log('yes ' this.name + 'can earn');

}

此时,人与动物的功能没有任何关系。然而,我们知道人也是动物。人工构造有两个问题。

  1. 它有重复的名称和年龄初始化代码。为此,应使用动物建造师。
  2. 它与动物建造师没有任何联系

上述两个问题可以通过在动物和人类功能构建者之间创建继承来消除。

您可以通过如下修改人工函数来解决代码复制的问题1:

1

2

3

4

function human(name, age, money) {

    animal.call(this, name, age);

    this.money = money;

}

现在,在人类函数中,我们使用call方法手动传递当前对象作为动物函数中“this”的值。这种方法也称为间接调用模式。现在,可以创建一个人类对象实例,如下所示:

1

2

var h1 = new human('dj', 30, '2000 $');

console.log(h1);

到目前为止,我们已经解决了代码复制的第一个问题,但是人类的功能仍然与动物的功能无关。如果您尝试对h1对象调用canrun方法,javascript将向您抛出一个错误。

1

h1.canRun(); // throw error canRun is not a function

您可以通过将人类功能原型与动物功能构造函数原型链接来解决这个问题。有两种方法可以做到这一点。

使用γ原型

使用object.create()方法

您可以使用object.create()链接函数构造函数的原型,如下所示:

1

human.prototype = Object.create(animal.prototype);

您可以使用_uu proto_uuu链接函数构造函数的原型,如下所示:

1

human.prototype.__proto__ = animal.prototype;

更推荐object.create()方法,因为在许多浏览器中可能不支持_uuProto。在链接原型之后,在一种方式下,您已经在动物和人类函数构造函数之间创建了继承。人的对象实例可以读取动物功能的所有属性,并且可以执行动物功能方法。

下面列出了实现函数构造函数之间继承的完整源代码,供您参考:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

function animal(name, age) {

  

    this.name = name;

    this.age = age;

  

}

  

animal.prototype.canRun = function () {

  

    console.log('yes ' this.name + ' can run !');

}

  

var dog = new animal('foo', 5);

dog.canRun();

  

var cat = new animal('koo', 3);

cat.canRun();

function human(name, age, money) {

    animal.call(this, name, age);

    this.money = money;

}

  

human.prototype = Object.create(animal.prototype);

  

human.prototype.canEarn = function () {

    console.log('yes ' this.name + 'can earn');

}

// human.prototype.__proto__ = animal.prototype;

var h1 = new human('dj', 30, '2000 $');

h1.canRun();

h1.canEarn();

要在函数构造函数之间创建继承,请始终执行以下两个操作:

  1. 使用call或apply调用父构造函数。
  2. 将子构造函数原型链接到父构造函数原型

转载于:https://my.oschina.net/u/4009527/blog/2995846

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/537224.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

python爬虫ssl错误_Python爬虫:Requests的SSLError:certificate verify failed问题解决方案6条...

问题:脚本是用Python写的,用到开源库play-scraper,调用其collectionAPI来获取Google Play的Top App列表。该库使用了requests作为客户端来对Google Play进行操作。当脚本执行时,会报如下错误:certificate verify faile…

2019年1月3日

数组 字面量创建数组 1. var arr[]; []里边可以放数字,字符串,true,false,null,undefined,数组([1,2,3]),对象{x:1,y:2} var arr[1,2…

vertex 3.0 与SpringBoot混合开发之初探

SpringBoot是最近几年比较流行的web应用开发框架,它是微服务的一个开发框架。它的Web服务器内核为Tomcat或Jetty,它们作为Servlet容量来对客户端的http/https请求进行解析。最近,spring.io又出推出一套新的服务器内核框架,它就是W…

switch芯片和phy芯片的区别_感应式芯片卡CPU卡的FM1208-9和FM1208-10有什么区别,你知道吗?...

感应式CPU卡是目前芯片卡中安全系统较高的芯片,使用范围也较为广泛,但是这款CPU分为FM1208-9和FM1208-10,那你们知道分别代表什么意思呢?他们之间有什么不同呢?CPU白卡FM是什么?首先,我们来说下…

每次登陆都要滑动验证_湖人队冠军成员卡鲁索很吃香:每次谈判都有N支球队点名要他...

10月24日NBA直播台讯:洛杉矶湖人队助理教练迈克-彭伯西在接受媒体采访时透露,湖人队替补控球后卫卡鲁索目前在联盟中很吃香。湖人队每次进行交易谈判时,对方球队都点名想要卡鲁索。彭伯西表示:“每一次我们在休赛期或者交易截止日…

[HAOI2015]按位或

朴素的 f[S]表示S到(1<<n)的期望次数 发现1的个数只增加不减少 所以可以类似拓扑序的图&#xff0c;然后枚举子集O(3^n)转移 没有优化的余地 另辟蹊径&#xff1a; 拆开每一位来看 t[i]表示第i位变成1的次数 ansE(max(t[i])) 根据min-max容斥 得到&#xff1a;ans∑E(t[i…

MySQL在DOS指令里面的使用以及增删改查的使用

本人的第一条博客&#xff0c;选中我的电脑单机右键&#xff0c;点开管理&#xff0c;选中服务找到MySQL57.启动该服务。回退至桌面&#xff0c;按住winR 输入cmd打开DOS指令的窗口。 在窗口输入: mysql -h localhost -u root -p 显示password输入提示&#xff1a;表示已经…

node+socket.io 实现一个聊天室

我们只做简单的实现&#xff0c;不接入数据库&#xff0c;nodejs也不使用express和koa等框架 因此依赖只有两个&#xff1a; 1、socket.io 2、mime&#xff08;用于获取静态资源时获取文件的mime类型&#xff09; 安装命令&#xff1a; npm install socket.io mime --save 其他…

安卓应用用户数据_用户指标数据应用

一、如何理解数据用户数据&#xff1a;gender:性别、 birthday:出生日期行为数据&#xff1a;user_id:用户id、auction_id:购买行为编号、buy_mount:购买数量、day:购买时间商品数据&#xff1a;cat_id:商品种类ID、cat1:商品类别、property:商品属性二、用户数据指标1.用户数据…

三大数据库数据库端口号及连接jdbc驱动下载

Jdbc连接三大数据库&#xff08;mysql sqlserver oracle&#xff09; Mysql:端口号为&#xff1a;3306&#xff08;默认&#xff09; 用java连接mysql数据库 Try{Class.forName(“com.mysql.jdbc.Driver”); //DatabaseName:需要连接的数据库名称 String url”jdbc:mysql://12…

webgis从基础到开发实践_开源WebGIS教程系列——11.1 GISLite 的开发背景与设计

地理信息门户可以帮助人们更容易地发现、访问和使用地理空间信息&#xff0c; 是地理信息发布、服务和共享的重要环节。许多国家都很重视地理信息门户的 建设&#xff0c;把它作为国家空间数据基础设施(spatial data infrastructure&#xff0c;SDI)的重要组成部分。GISLite 是…

Oracle数据库及在DOS命令下面的简单操作

在Oracle数据库注释用--表明为注释&#xff0c;但以下用//或--代表解释;数据库不怎么区分大小写&#xff1b; 先说说一些简单Oracle数据库操作的语句&#xff1a; 使用语句创建普通用户&#xff1a; Create user username identified by password; //创建普通用户 Grant reso…

CSS属性(display)

1.display属性 <!DOCTYPE html> <html lang"zh-CN"> <head><meta charset"UTF-8"><title>08display属性</title><style>.c1 {background-color: red;/*display: none; !* 让其在页面上不显示 *!*//*display: i…

产品发布系统_【产品发布】第3期|阀门遥控系统

更多精彩&#xff0c;请点击上方蓝字关注我们&#xff01;常熟瑞特电气股份有限公司的阀门遥控系统是一款经典的产品线&#xff0c;包括了全系列的液压执行器&#xff0c;电液执行器&#xff0c;微型动力单元&#xff0c;液压动力泵站&#xff0c;液压电磁阀箱等产品。阀门遥控…

大数据就业前景,分析的太到位了

大数据广泛应用于电网运行、经营管理及优质服务等各大领域&#xff0c;并正在改变着各行各业&#xff0c;也引领了大数据人才的变革。大数据就业前景怎么样&#xff1f;这对于在就业迷途中的我们是一个很重要的信息。 随着大数据时代的到来【这次国家教育部也改革动真格了】&am…

常用集合(List,Set,Map)的基本定义和操作

集合类存放于java.util包中。 集合类存放的都是对象的引用&#xff0c;而非对象本身&#xff0c;出于表达上的便利&#xff0c;我们称集合中的对象就是指集合中对象的引用&#xff08;reference)。 常用的集合类型主要有3种&#xff1a;set(集&#xff09;、list(列表&#x…

多麦克风做拾音的波束_麦克风丨人声应该用动圈话筒还是电容话筒?

无论是在您最喜欢的乐队的纪录片中&#xff0c;还是在电影中那些有关录音棚里的场景中&#xff0c;似乎都存在着一个共同的主题&#xff0c;那就是&#xff1a;歌手们都在使用大振膜的电容麦克风进行录音。我知道人们应该从别人的经验中汲取精华&#xff0c;事半功倍。但是我并…

MYSQL安装与库的基本操作

mysql数据库 什么是数据库 # 用来存储数据的仓库 # 数据库可以在硬盘及内存中存储数据 数据库与文件存储数据区别 数据库本质也是通过文件来存储数据, 数据库的概念就是系统的管理存储数据的文件 数据库介绍 数据库服务器端: 存放数据的主机集群数据库端: 可以连接数据库的任意…

java框架mybatis配置文件总结一

先新建个java EE的项目 该配置文件必须在src的目录下面&#xff0c; 新建一个xml 文件&#xff1a; 建完后发现它会自动建在web目录下面&#xff0c;我们把这个文件移到src目录下面&#xff1a; &#xff08;注&#xff1a;对了&#xff0c;该文件的编码最好用utf-8的no bom,…

python第六周实验_第六周实验四

二.实验的内容(1)根据下面的要求实现圆类Circle。1.圆类Circle的成员变量&#xff1a;radius表示圆的半径。2.圆类Circle的方法成员&#xff1a;Circle():构造方法&#xff0c;将半径置0Circle(double r)&#xff1a;构造方法&#xff0c;创建Circle对象时将半径初始化为rdoubl…