js中Function引用類型常見有用的方法和屬性詳解

發布時間:2019-12-11 16:12 來源:互聯網 當前欄目:網站服務器

Function類型

函數由于是Function類型的一個實例,所以函數名就是一個指向函數對象的指針,不會與某個函數死死的連接在一起,這也導致了js中沒有真正的重載,但好處是,函數對象可以作為另一個函數的參數或是返回值;

訪問一個函數對象的指針而不是執行函數本身不能加括號

var func = new Function("x", "y", "return x + y");// 構造函數來實例化一個Function類型, 但不推薦使用
function func(x, y){
  return x + y;
}// 函數聲明 js引擎會將所有的函數聲明提升到頂部
var func = function (x, y){ return x + y };// 函數表達式 變量的賦值, 變量func保存著 function(x, y){ return x + y} 這個對象

Function類型中,有兩個特殊的對象:arguments和this , 前者里面有傳入函數中所有的參數,還有一個callee屬性,這是個指針指向擁有這個屬性的Function實例;而this這個指針指向執行環境,也就是Global類型的一個實例. 在瀏覽器中是一個窗口.

function b(){
  console.log(arguments.callee);
}

Function類型的屬性和方法

length // Funciton實例期望接收形式參數的個數
prototype // 

apply();// 非繼承的方法 
// apply(Function實例運行的作用域:this, Array實例或arguments)

call();// 非繼承的方法
// call(Function實例運行的作用域:this, arg1, arg2, ...)

//

bind( X );// 將Function的實例的this指向 對象 X

除此之外,Function類型中還有一個特殊的屬性:caller,這是個指針,在嚴格模式下不能對這個屬性賦值.

Function類型一個實例a調用了Function類型的另一個實例b, 那么實例b中的caller屬性就會指向實例a;

function a(){
  b();
}
function b(){
  console.log(arguments.callee.caller);
}

以上就是本次介紹的全部相關知識點,感謝大家的學習和對IIS7站長之家的支持。

  • 1、
  • 2、
  • 3、
  • 4、
  • 5、
  • 6、
  • 7、
  • 8、
  • 9、
  • 10、
  • 11、
  • 12、
  • 13、
  • 14、
  • 15、
  • 16、
  • 17、
  • 18、
  • 19、
  • 20、
  • 21、
  • 22、
  • 23、
  • 24、
  • 25、
  • 1、
  • 2、
  • 3、
  • 4、
  • 5、
  • 6、
  • 7、
  • 8、
  • 9、
  • 10、
  • 11、
  • 12、
  • 13、
  • 14、
  • 15、
  • 16、
  • 17、
  • 18、
  • 19、
  • 20、
  • 21、
  • 22、
  • 23、
  • 24、
  • 25、