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();//打印出"我是一个猴子"
  • 相关阅读:
    在chrome插件开发中,如何executeScript多个content script文件
    [Silverlight]MVVM+MEF框架Jounce练习(1)
    EF的日期运算
    【silverlight】Silverlight TreeViw默认展开节点
    singleton pattern简单随笔
    Design pattern形象比喻
    C#简单选择排序
    回文算法
    C#插入排序
    Jquery调用存储过程实例
  • 原文地址:https://www.cnblogs.com/zhengwei-cq/p/10466466.html
Copyright © 2011-2022 走看看