zoukankan      html  css  js  c++  java
  • javascript公有静态成员

    公共静态成员
    在javascript中并没有特殊语法来表示静态成员。但是可以通过使用构造函数向其添加属性这种方式。

    //构造函数
    var Gadget = function(){};
    
    //静态方法
    Gadget.isShiny = function(){
      return 'you bet';
    }
    
    //向该原型添加一个普通方法
    Gadget.prototype.setPrice = function(price){
      this.price = price;
    }
    //调用静态方法 console.log( Gadget.isShiny() ); //输出'you bet' //创建一个实例并调用其方法 var iphone = new Gadget(); iphone.setPrice(500); //试图调用构造函数静态方法 iphone.isShiny(); //报错 以上代码可以看错,试图以一个实例方法调用构造函数的静态方法会报错,所以我们需要做一些改动,代码如下: //构造函数 var Gadget = function(price){   this.price = price; }; //静态方法 Gadget.isShiny = function(){   var msg = 'you bet';   //只有实例才会执行   if( this instanceof Gadget ){     msg += ', it costs $' + this.price + '!';   }   return msg; } //向该原型添加一个普通方法 Gadget.prototype.isShiny = function(){   return Gadget.isShiny.call(this); } //静态方法调用 console.log( Gadget.isShiny() ); //输出:'you bet' //测试实例,非静态调用 var a = new Gadget(499.99); console.log( a.isShiny() ); //输出:'you bet, it costs $499.99!'

      

  • 相关阅读:
    bazel-编译静态库
    bazel-demo2_1
    160个creakme(八)
    适合新手的160个creakme(四)
    熊猫烧香病毒逆向分析
    适合新手的160个creakme(三)
    适合新手的160个creakme(二)
    适合新手的160个creakme(一)
    shell脚本练习题
    Core dump文件和ECFS
  • 原文地址:https://www.cnblogs.com/fengzekun/p/3894448.html
Copyright © 2011-2022 走看看