DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> JavaScript入門知識 >> JavaScript綜合知識 >> 解析JavaScript中的不可見數據類型
解析JavaScript中的不可見數據類型
編輯:JavaScript綜合知識     

 這篇文章主要是對JavaScript中的不可見數據類型進行了詳細的介紹,需要的朋友可以過來參考下,希望對大家有所幫助

JS提供了一些內置對象、函數和構造器供我們編程,如Math、parseInt、Object、Array等。這些都是可見的,編程時可以使用的。比如我可以new Object 或 new Array。   有一些則是不可見的,這些對象只能由引擎在特殊的情形提供。這些類型的對象往往還被消減了一些功能。下面列舉一些   一、Arguments 類型 Arguments 類型 不能由程序員手動創建其對象,即你不能 new Arguments() 。 它有且僅有一個對象arguments     復制代碼 代碼如下: function func() {      console.log(arguments[0])     // 1      console.log(arguments.length) // 3  }  func(1, 2, 3)    arguments對象是在函數調用的時候創建的,只在函數內部可見和使用。可以看到arguments很象Array,可以按索引取元素,也有length屬性。但它不是Array,它沒有Array的有一些方法比如push、pop等。Arguments 在ES5 10.6 裡定義。   二、bind返回的函數很特殊 bind是ES5給Function.prototype新增的一個方法,它和call/apply一樣在function上直接調用。它返回一個指定了上下文和參數的函數。     復制代碼 代碼如下: 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    可以看到返回的函數f1和普通函數一樣使用小括號執行調用了。 一切正常,但下面的代碼會讓你大跌眼鏡 復制代碼 代碼如下: 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    和上面代碼比較,就最後一句不同,沒有執行f1(),而是打印出f1.prototype,發現是undefined。   奇怪嗎? 每個function不都有一個prototype屬性嗎,這是用來實現原型繼承的哦。的確,bind返回的function比較特殊,它沒有prototype。這種特殊的函數是由JS引擎創建的,客戶端程序員沒法通過函數聲明或函數直接量得到。   這一點在規范裡有明確提示 ES5 15.3.4.5  
XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved