美文网首页
JS中的实例方法与静态方法

JS中的实例方法与静态方法

作者: Bior | 来源:发表于2020-04-20 21:41 被阅读0次

    一、静态方法与实例方法的例子:

    我们先来看一个例子来看一下JS中的静态方法和实例方法到底是什么

    静态方法:

    function A(){}
    A.sayMeS=function(){
    console.log("Hello World S!");
    }
    A.sayMeS();//输出Hello World S!
    

    实例方法:

    function A(){}
    A.prototype.sayMeE=function(){
    console.log("Hello World E!");
    }
    var a=new A();
    a.sayMeE();//输出Hello World E!
    

    二、二者的区别:

    从定义上,实例方法要用到function这个对象中的prototype属性来定义,静态方法通过A.直接定义;从方法调用上,静态方法可以直接通过A.来调用,实例方法要通过先定义一个引用变量,指向构造函数定义的新对象。

    函数是一个对象,函数对象中的属性 prototype可以想成一个指针,指向一个方法(这样不用每一次用构造函数创造一个新实例后都要将方法重新创建一遍)。这样就好理解了,var a是A的一个引用,也就是指针,a就可以指向sayMeE这个方法,如果直接A.sayMeE()是会报错的,因为A不是一个指针,a.sayMeS()也会报错,因为a不是一个方法对象。

    三、再谈继承:

    继承举例:

    function A(){
    }
    A.prototype.sayMeE=function(){
    console.log("Hello World E!");
    }
    function B(){
    }
    B.prototype=new A();//实现了继承
    

    继承就是将B的指针指向A对象,这种形式是用A的构造函数来构建对象。

    相关文章

      网友评论

          本文标题:JS中的实例方法与静态方法

          本文链接:https://www.haomeiwen.com/subject/mvjsihtx.html