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();//打印出"我是一个猴子"
  • 相关阅读:
    case 条件语句
    shell 函数
    if条件语句
    IP地址分类和分段
    shell脚本的条件测试与比较
    bc命令
    [LeetCode]Remove Duplicates from Sorted Array II
    [LeetCode]Merge Two Sorted Lists
    [LeetCode]Climbing Stairs
    [LeetCode]Merge Intervals
  • 原文地址:https://www.cnblogs.com/zhengwei-cq/p/10466466.html
Copyright © 2011-2022 走看看