有關(guān)于JS輔助函數(shù)inherit()的問題
最近在閱讀《JavaScript權(quán)威指南》(第六版)在第六章P122有這么一段代碼:
// 返回一個(gè)繼承自原型對象proto的屬性的新對象
// 這里可以用到ES5的Object.create()函數(shù)
function inherit(proto) {
//proto是一個(gè)對象,但不能是null
if(proto == null) throw TypeError();
if(Object.create) return Object.create(proto); //如果Object.create()存在,使用它
var t = typeof proto; //否則進(jìn)一步檢查
if(t!=='object' && t!=='function') throw TypeError();
var F = function() {}; // 定義一個(gè)空構(gòu)造函數(shù)
F.prototype = proto; // 將其原型屬性設(shè)置為proto
return new F(); // 使用F()創(chuàng)建proto的繼承對象
}
很明顯輔助函數(shù)的用途是創(chuàng)建一個(gè)繼承父類原型的新對象
問題
在關(guān)于下面的這句判斷時(shí),一時(shí)無法理解
var t = typeof proto; //否則進(jìn)一步檢查
if(t!=='object' && t!=='function') throw TypeError();
我們的印象中原型對象應(yīng)該是個(gè)Object或者直接是字面量,那么傳遞的參數(shù)類型會有“function”類型情況嗎
理解
函數(shù)也是對象,也可以有自己的屬性和方法。等等,這不是我們的靜態(tài)屬性和方法啊!這里是指把函數(shù)看成可以添加屬性的對象
// 測試傳遞function類型
var func = function() {};
func.text = 'good work';
func.getText = function() {
return func.text;
};
console.log(typeof func); // 'function'
// 傳遞function類型,返回以func為原型的新對象
var subFunc = inherit(func);
console.log(subFunc.getText()); // 輸出:'good work'
好吧,一個(gè)證明說明。原來是可以傳遞'function'類型的
相關(guān)文章
JavaScript學(xué)習(xí)筆記整理_關(guān)于表達(dá)式和語句
下面小編就為大家?guī)硪黄狫avaScript學(xué)習(xí)筆記整理_關(guān)于表達(dá)式和語句。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2016-09-09
JavaScript中日期的相關(guān)操作方法總結(jié)
這篇文章主要介紹了JavaScript中日期的相關(guān)操作方法總結(jié),是JS入門學(xué)習(xí)中的基礎(chǔ)知識,需要的朋友可以參考下2015-10-10

