在多数语言中继承都很重要。JavaScript是一个基于原型的语言,这意味着对象可以直接从其他对象继承。以下列出几种常见的js继承方式。

  1. 原型链继承

    function Father(){
    this.status = true;
    }
    Father.prototype.getSuper = function(){
    return this.status;
    };
    function Son(){
    this.substatus = false;
    }
    //继承了 SuperType
    Son.prototype = new Father();
    Son.prototype.getSub = function (){
    return this.substatus;
    };
    var instance = new Son();
    alert(instance.getSuper()); //true
  2. 借用构造函数继承
    function Father(){
    this.colors = [1,2,3];
    }
    function Son(){
    //继承了 Father
    Father.call(this);
    }
    var instance1 = new Son();
    instance1.colors.push(4);
    alert(instance1.colors); //"1,2,3,4"
    var instance2 = new Son();
    alert(instance2.colors); //"1,2,3"
  3. 组合继承
    function Father(name){
    this.name = name;
    }
    Father.prototype.sayName = function(){
    alert(this.name);
    };
    function Son(name, age){
    //继承属性
    SuperType.call(this, name);
    this.age = age;
    } Son.prototype = new Father(); //将子类的原型指向父类
    Son.prototype.constructor = Son; //将子类的constructor指向自己
    Son.prototype.sayAge = function(){
    alert(this.age);
    };
    var instance = new Son("lh", 19);
    instance1.sayName(); //"lh";
    instance1.sayAge(); //19
  4. 原型式继承
    function object(o){
    function F(){}
    F.prototype = o;
    return new F();
    }
    var person = {
    name: "lh",
    loves: ["a", "b", "c"]
    };
    var anotherPerson = object(person);
    anotherPerson.name = "Greg";
    anotherPerson.friends.push("d");
    alert(person.loves); //"a,b,c,d"

    这里的object方法和Object.create()方法类似。

  5. 寄生式继承
    function object(o){
    function F(){}
    F.prototype = o;
    return new F();
    }
    function createAnother(obj){
    var clone = object(obj); //通过调用函数创建一个新对象
    clone.say = function(){ //给这个对象添加方法
    alert("hi");
    };
    return clone; //返回这个对象
    }
    var person = {
    name: "lh",
    loves: ["a", "b", "c"]
    };
    var anotherPerson = createAnother(person);
    anotherPerson.say(); //"hi"
  6. 寄生组合式继承
    function inheritPrototype(son, father){
    var prototype = Object.create(father.prototype);
    son.prototype = prototype;
      prototype.constructor = son;
    }
    function Father(name){
    this.name = name;
    }
    Father.prototype.sayName = function(){
    alert(this.name);
    };
    function Son(name, age){
    Father.call(this, name);
    this.age = age;
    }
    inheritPrototype(Son, Father);
  7. 使用es6实现
    class Father{
    constructor(x, y) {
    this.x = x;
    this.y = y;
    }
    }
    class son extends Father{
    constructor(x, y, age) {
    super(x, y); // 调用父类的constructor(x, y)
    this.age= age;
    }
    toString() {
    return this.color + ' ' + super.toString(); // 调用父类的toString()
    }
    }
    子类继承父类中constructor中必须先调用super()方法才能访问this,否则会报错。

原生js实现继承的更多相关文章

  1. koa 基础(十七)原生 JS 中的类、静态方法、继承

    1.app.js /** * 原生 JS 中的类.静态方法.继承 * es5中的类和静态方法 */ function Person(name, age) { // 构造函数里面的方法和属性 this. ...

  2. 用原生JS读写CSS样式的方法总结

    为了日后方便查询,本人翻阅了一些资料总结了以下方法,仅限原生JS,如有不对的地方欢迎指出!只求大家看完觉得有学到点什么就OK了!   一.可以通过DOM节点对象的style对象(即CSSStyleDe ...

  3. 框架操作DOM和原生js操作DOM比较

    问题引出 对于Angular和React操作DOM的速度,和原生js操作DOM的速度进行了一个比较: 一个同学做的demo 代码如下: <!DOCTYPE html> <html n ...

  4. 原生js dom记忆的内容

    1.DOM基础getElementByIdgetElementByTagNamegetElementByName getElementsByClass querySelector querySelec ...

  5. 原生JS面向对象思想封装轮播图组件

    原生JS面向对象思想封装轮播图组件 在前端页面开发过程中,页面中的轮播图特效很常见,因此我就想封装一个自己的原生JS的轮播图组件.有了这个需求就开始着手准备了,代码当然是以简洁为目标,轮播图的各个功能 ...

  6. 原生js+css实现重力模拟弹跳系统的登录页面

    今天小颖把之前保存的js特效视频看了一遍,跟着视频敲了敲嘻嘻,用原生js实现一个炫酷的登录页面.怎么个炫酷法呢,看看下面的图片大家就知道啦. 效果图: 不过在看代码之前呢,大家先和小颖看看css中的o ...

  7. 原生Js操作DOM

    查找DOM .querySelectorAll(),它接受包含一个CSS选择器的字符串参数,返回一个表示文档中匹配选择器的所有元素的NodeList元素. .querySelector(),返回第一个 ...

  8. 原生JS插件(超详细)

    作为一个前端er,如果不会写一个小插件,都不好意思说自己是混前端界的.写还不能依赖jquery之类的工具库,否则装得不够高端.那么,如何才能装起来让自己看起来逼格更高呢?当然是利用js纯原生的写法啦. ...

  9. 原生js实现vue组件功能

    在如今VUE盛行的情况下,我们一直在惊叹于VUE的组件的功能,却不知道,原生js早就已经支持了这个功能. 最近在公开课学到的,js还有很多很多需要探索学习. 下面是一个简单的例子 <!DOCTY ...

随机推荐

  1. JasperStudio 输出pdf 出错。

    发表于 2008-09-23 09:35:15 楼主net.sf.jasperreports.engine.JRException: Error retrieving field value from ...

  2. jQuery迷你帮助查找功能

    在线演示 本地下载

  3. Framework7 下拉刷新

    html结构 <div class="page"> <!-- Page content should have additional "pull-to- ...

  4. ActivityManagerService

    先上类图: 基本类说明和运行框架图中蓝色表示AMS进程,黄色表示app进程.1. 全局调度者在android中,AMS是activity和进程的全局调度者,也就是说系统中载入和准备载入的activit ...

  5. Servlet工作流程

    1.加载Servlet类 类加载器负责加载servlet类. 当Web容器接收到servlet的第一个请求时,将加载servlet类. 2.创建Servlet实例 Web容器在加载servlet类之后 ...

  6. JavaScript中操作数组的方法

    JavaScript Array 对象 对数组操作的方法分为两种 一种是会改变原始数组的变异方法,还有一种是不会改变原始数组的非变异方法. 总结 巧记 Push() 尾部添加 pop() 尾部删除 U ...

  7. 巨蟒python全栈开发-第11阶段 ansible3_3入门playbook剧本

    1.playbook剧本 2.playbook传参 3.setup模块介绍 4.playbook的tags 5.playbook的handlers&&templates模块 6.条件和 ...

  8. 一维数组的求平均成绩 Day06

    package com.sxt.arraytest1; /* * 求班里学生的平均成绩,以及成绩的综合 输出每个同学的成绩 */ import java.util.Arrays; import jav ...

  9. iOS 设计 用户为王 - 关于征询授权、注册及加载等待的体验优化

    你要做的东西一定要是你无比渴望这世界上能出现的东西,这股热情和能量将会融入到你的应用中,成为它腾飞的初速度,为你带来积极反馈.把自己当做app最重要的用户,这一点非常重要. http://www.co ...

  10. oracle函数 VARIANCE([distinct|all]x)

    [功能]统计数据表选中行x列的方差. [参数]all表示对所有的值求方差,distinct只对不同的值求方差,默认为all 如果有参数distinct或all,需有空格与x(列)隔开. [参数]x,只 ...