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();//打印出"我是一个猴子"
  • 相关阅读:
    Decompiling XAPK Files
    ps4双手柄inputManager设置
    游客须知
    页面类
    Temp
    Web AppDomain
    委托和事件
    动态执行js
    遍历对象属性,成员,方法的方法
    用Windows操作系统的人有时会遇到这样的错误信息:
  • 原文地址:https://www.cnblogs.com/zhengwei-cq/p/10466466.html
Copyright © 2011-2022 走看看