js中Function引用類型常見有用的方法和屬性詳解
Function類型
函數(shù)由于是Function類型的一個實例,所以函數(shù)名就是一個指向函數(shù)對象的指針,不會與某個函數(shù)死死的連接在一起,這也導致了js中沒有真正的重載,但好處是,函數(shù)對象可以作為另一個函數(shù)的參數(shù)或是返回值;
訪問一個函數(shù)對象的指針而不是執(zhí)行函數(shù)本身不能加括號
var func = new Function("x", "y", "return x + y");// 構造函數(shù)來實例化一個Function類型, 但不推薦使用 function func(x, y){ return x + y; }// 函數(shù)聲明 js引擎會將所有的函數(shù)聲明提升到頂部 var func = function (x, y){ return x + y };// 函數(shù)表達式 變量的賦值, 變量func保存著 function(x, y){ return x + y} 這個對象
Function類型中,有兩個特殊的對象:arguments和this , 前者里面有傳入函數(shù)中所有的參數(shù),還有一個callee屬性,這是個指針指向擁有這個屬性的Function實例;而this這個指針指向執(zhí)行環(huán)境,也就是Global類型的一個實例. 在瀏覽器中是一個窗口.
function b(){ console.log(arguments.callee); }
Function類型的屬性和方法
length // Funciton實例期望接收形式參數(shù)的個數(shù) 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); }
以上就是本次介紹的全部相關知識點,感謝大家的學習和對腳本之家的支持。
相關文章
Javascript實現(xiàn)鼠標框選操作 不是點擊選取
這篇文章主要介紹了Javascript實現(xiàn)鼠標框選操作,不是點擊選取,利用鼠標進行框選,感興趣的小伙伴們可以參考一下2016-04-04javascript中setAttribute()函數(shù)使用方法及兼容性
這篇文章主要介紹了javascript中setAttribute()函數(shù)使用方法及兼容性的相關資料,需要的朋友可以參考下2015-07-07使用mini-define實現(xiàn)前端代碼的模塊化管理
這篇文章主要介紹了使用mini-define實現(xiàn)前端代碼的模塊化管理,十分不錯的一篇文章,這里推薦給有需要的小伙伴。2014-12-12JS基于clipBoard.js插件實現(xiàn)剪切、復制、粘貼
這篇文章主要介紹了JS實現(xiàn)剪切、復制、粘貼——clipBoard.js 的相關資料,需要的朋友可以參考下2016-05-05