溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

javascript函數(shù)寫法有哪些

發(fā)布時(shí)間:2021-08-20 11:17:48 來(lái)源:億速云 閱讀:124 作者:小新 欄目:web開發(fā)

這篇文章將為大家詳細(xì)講解有關(guān)javascript函數(shù)寫法有哪些,小編覺得挺實(shí)用的,因此分享給大家做個(gè)參考,希望大家閱讀完這篇文章后可以有所收獲。

1.常規(guī)寫法

 function fnName(){
  console.log("常規(guī)寫法");
}

2.匿名函數(shù),函數(shù)保存到變量里

var myfn = function(){
  console.log("匿名函數(shù),函數(shù)保存到變量里");
 }

3.如果有多個(gè)變量,可以用對(duì)象收編變量

3.1 用json對(duì)象

 var fnobject1={
   fn1:function(){
      console.log("第一個(gè)函數(shù)");
   },
   fn2:function(){
      console.log("第二個(gè)函數(shù)");
   },
   fn3:function(){
      console.log("第三個(gè)函數(shù)");
   }
 }

3.2 聲明一個(gè)對(duì)象,然后給它添加方法

 var fnobject2 = function(){};
 fnobject2.fn1 = function(){
   console.log("第一個(gè)函數(shù)");
 }
 fnobject2.fn2 = function(){
   console.log("第二個(gè)函數(shù)");
 }
 fnobject2.fn3 = function(){
   console.log("第三個(gè)函數(shù)");
 }

3.3 可以把方法放在一個(gè)對(duì)象函數(shù)里

 var fnobject3 = function(){
   return {
     fn1:function(){
       console.log("第一個(gè)函數(shù)");
       },
     fn2:function(){
       console.log("第二個(gè)函數(shù)");
     },
      fn3:function(){
       console.log("第三個(gè)函數(shù)");
     }  
   }  
 };

4.可用類來(lái)實(shí)現(xiàn),注意類的第二種和第三種寫法不能混用,否則一旦混用,如在后面為對(duì)象的原型對(duì)象賦值新對(duì)象時(shí),那么他將會(huì)覆蓋掉之前對(duì)prototype對(duì)象賦值的方法

4.1 第一種寫法

 var fnobject4 = function(){
   this.fn1 = function(){
     console.log("第一個(gè)函數(shù)");
  }
   this.fn2 = function(){
     console.log("第二個(gè)函數(shù)"); 
   }
   this.fn3 = function(){
     console.log("第三個(gè)函數(shù)");
   }
 };

4.2 第二種寫法

 var fnobject5 = function(){};
 fnobject5.prototype.fn1 = function(){
   console.log("第一個(gè)函數(shù)");
 }
 fnobject5.prototype.fn2 = function(){
   console.log("第二個(gè)函數(shù)");
 }
 fnobject5.prototype.fn3 = function(){
   console.log("第三個(gè)函數(shù)");
 }

4.3 第三種寫法

 var fnobject6 = function(){};
 fnobject6.prototype={
   fn1:function(){
     console.log("第一個(gè)函數(shù)");
   },
   fn2:function(){
     console.log("第二個(gè)函數(shù)");
   },
   fn3:function(){
     console.log("第三個(gè)函數(shù)");
   }
 }

4.4 第四種寫法

var fnobject7 = function(){};
fnobject7.prototype={
  fn1:function(){
    console.log("第一個(gè)函數(shù)");
    return this;
  },
    fn2:function(){
    console.log("第二個(gè)函數(shù)");
    return this;
  },
  fn3:function(){
    console.log("第三個(gè)函數(shù)");
    return this;
  }
}

5.對(duì)Function對(duì)象類的擴(kuò)展(下面三種只能用一種)

5.1 第一種寫法(對(duì)象)

 Function.prototype.addMethod = function(name,fn){
   this[name] = fn;
 }
 var methods=function(){};//var methods=new Function();
 methods.addMethod('fn1',function(){
   console.log("第一個(gè)函數(shù)");
 });
 methods.addMethod('fn2',function(){
   console.log("第二個(gè)函數(shù)");
 });
 methods.addMethod('fn3',function(){
   console.log("第三個(gè)函數(shù)");
 });

5.2 鏈?zhǔn)教砑樱▽?duì)象)

Function.prototype.addMethod = function(name,fn){
  this[name] = fn;
   return this;
 }
 var methods=function(){};//var methods=new Function();
 methods.addMethod('fn1',function(){
   console.log("第一個(gè)函數(shù)");
 }).addMethod('fn2',function(){
   console.log("第二個(gè)函數(shù)");
 }).addMethod('fn3',function(){
   console.log("第三個(gè)函數(shù)");
 });

5.3 鏈?zhǔn)教砑樱悾?/p>

Function.prototype.addMethod = function(name,fn){
  this.prototype[name] = fn;
  return this;
}
var Methods=function(){};//var methods=new Function();
methods.addMethod('fn1',function(){
  console.log("第一個(gè)函數(shù)");
}).addMethod('fn2',function(){
  console.log("第二個(gè)函數(shù)");
}).addMethod('fn3',function(){
  console.log("第三個(gè)函數(shù)");
});

關(guān)于“javascript函數(shù)寫法有哪些”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,使各位可以學(xué)到更多知識(shí),如果覺得文章不錯(cuò),請(qǐng)把它分享出去讓更多的人看到。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI