JS提供了一些內(nèi)置對(duì)象、函數(shù)和構(gòu)造器供我們編程,如Math、parseInt、Object、Array等。這些都是可見的,編程時(shí)可以使用的。比如我可以new Object 或 new Array。
有一些則是不可見的,這些對(duì)象只能由引擎在特殊的情形提供。這些類型的對(duì)象往往還被消減了一些功能。下面列舉一些
一、Arguments 類型
Arguments 類型 不能由程序員手動(dòng)創(chuàng)建其對(duì)象,即你不能 new Arguments() 。 它有且僅有一個(gè)對(duì)象arguments
復(fù)制代碼 代碼如下:
function func() { 
    console.log(arguments[0])     // 1 
    console.log(arguments.length) // 3 
} 
func(1, 2, 3) 
二、bind返回的函數(shù)很特殊
bind是ES5給Function.prototype新增的一個(gè)方法,它和call/apply一樣在function上直接調(diào)用。它返回一個(gè)指定了上下文和參數(shù)的函數(shù)。
復(fù)制代碼 代碼如下:
function func(age) { 
    console.log('name: ' + this.name + ', career: ' + age) 
} 
var person = {name: 'John McCarthy'} 
var f1 = func.bind(person, 'computer scientist') 
f1() // name: John McCarthy, career: computer scientist 
復(fù)制代碼 代碼如下:
function func(age) { 
    console.log('name: ' + this.name + ', career: ' + age) 
} 
var person = {name: 'John McCarthy'} 
var f1 = func.bind(person, 'computer scientist') 
console.log(f1.prototype) // undefined 
奇怪嗎? 每個(gè)function不都有一個(gè)prototype屬性嗎,這是用來實(shí)現(xiàn)原型繼承的哦。的確,bind返回的function比較特殊,它沒有prototype。這種特殊的函數(shù)是由JS引擎創(chuàng)建的,客戶端程序員沒法通過函數(shù)聲明或函數(shù)直接量得到。
這一點(diǎn)在規(guī)范里有明確提示 ES5 15.3.4.5
新聞熱點(diǎn)
疑難解答
圖片精選