zoukankan      html  css  js  c++  java
  • js 继承介绍

       js中继承的方式并不是明确的,这里介绍常用的几种

    一、对象冒充(构造函数绑定)

    原理:使用对象冒充继承基类,实质上是使用call或apply方法改变this 指针的指向

     function Monkey()
            {
                this.type = "猴子";
            }
            function MagicMonkey()
            {
                Monkey.call(this);
                this.skill = "法术";
            }
       

    这种方式可以实现多重继承的,当然用apply也是一样的

    二、原型链

    原理:使用prototype属性,prototype对象是个模版,要实例化的对象都以这个模版为基础,总而言之,prototype对象的任何属性和方法都被传递给那个类的所有实例,原型链利用这种功能来实现继承机制。

    function Monkey() { }
            Money.prototype.type = "猴子";
            Money.prototype.run = function () { alert("我是一个猴子")}
    
            function MagicMonkey() { }
            MagicMonkey.prototype = new Monkey();
            var wukong = new MagicMonkey();
            alert(wukong.type);//打印出“猴子”
            wukong.run();//打印出"我是一个猴子"

    注意:给子类加属性或方法时必须在 MagicMonkey.prototype = new Monkey(); 之后,要不会被覆盖,只能继承一个父类

    三、混合模式

    function Monkey(type) {
                Money.type = type;
            }
            Money.prototype.run = function () { alert("我是一个猴子")}
    
            function MagicMonkey(type) {
                Money.call(this,type);//只能继承构造函数中的信息,不能继承原型中的信息
            }
            MagicMonkey.prototype = new Monkey();
    
            var wukong = new MagicMonkey();
            alert(wukong.type);//打印出“猴子”
            wukong.run();//打印出"我是一个猴子"
  • 相关阅读:
    LeetCode59 Spiral Matrix II
    LeetCode58 Length of Last Word
    LeetCode54 Spiral Matrix
    LeetCode63 Unique Paths II
    LeetCode62 Unique Paths
    LeetCode55 Jump Game
    网易2017年校招笔试题 最大的奇约数
    Codeforces Round #119 (Div. 2)
    Codeforces Round #118 (Div. 2)
    2016 MIPT Pre-Finals Workshop Taiwan NTU Contest
  • 原文地址:https://www.cnblogs.com/zhengwei-cq/p/10466466.html
Copyright © 2011-2022 走看看