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();//打印出"我是一个猴子"
  • 相关阅读:
    堆和栈的区别(转)
    conversion to dalvik format failed with error 1的解决办法
    eclipse最实用快捷键
    java socket编程(转)
    Android 面试总结
    Android横竖屏总结(转)
    Android布局文件属性笔记(转)
    常用数据结构有哪些(转)
    经常用到的Eclipse快捷键(转)
    url编码转换
  • 原文地址:https://www.cnblogs.com/zhengwei-cq/p/10466466.html
Copyright © 2011-2022 走看看