DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> JavaScript入門知識 >> JavaScript基礎知識 >> W3C Group的JavaScript1.8 新特性介紹
W3C Group的JavaScript1.8 新特性介紹
編輯:JavaScript基礎知識     
JavaScript 1.8 計劃作為Gecko 1.9(將要合並在Firefox 3中)的一部分開始使用的。比起JavaScript 1.7來說,這只是很小的更新,不過它也確實包含了一些向ECMAScript 4/JavaScript 2進化的痕跡。JavaScript 1.8還將包含在JavaScript 1.6 和 JavaScript 1.7中的所有新特性。
使用 JavaScript 1.8
為了可以在HTML中使用 JavaScript 1.8 的新特性,需要如下這樣寫:
<script type="application/javascript;version=1.8"> ... 你的代碼 ... </script>
在使用 JavaScript shell 、JavaScript XPCOM 組件,或者 XUL <script> 元素的時候,就是自動使用最新的JS版本(Mozilla 1.9中的 JS1.8)。
如果需要使用新的關鍵字 "yield" 和 "let" 的話,你就要指定是1.7版本或者更高的版本,因為已經寫好的那些代碼可能會把這兩個關鍵字用作變量名或者函數名。如果並沒有使用任何新的關鍵字,就可以不用指定JavaScript的版本。
表達式閉包
這個新添加的特性其實就是簡單函數的方便寫法,使得這個語言更加類似典型的Lambda notation.
JavaScript 1.7 以及更老的版本:
function(x) { return x * x; }
JavaScript 1.8:
function(x) x * x
這個語法允許你省略花括號和 'return' 語句 -- 隱式的做它們的工作。用這種方法寫,就只是表面上看起來短了一些,並沒有其他好處。
示例:
綁定事件處理器的簡單寫法:
document.addEventListener("click", function() false, true);
把這個定義與JavaScript 1.6中的一寫數組函數一起使用:
elems.some(function(elem) elem.type == "text");
生成器表達式
這個新添加的特性,允許你簡單的創建生成器(在JavaScript 1.7引入的)。通常你以前需要創建一個自定義的函數,它含有一個 yield,但是這個新特性使你可以使用類似數組概念的語法來創建一個獨立的生成器句柄。
在 JavaScript 1.7 中,你可能需要寫出想下面這樣的代碼來為一個對象創建自定義的生成器:
function add3(obj) {
for ( let i in obj )
yield i + 3;
}
let it = add3(someObj);
try {
while (true) {
document.write(it.next() + "<br>\n");
}
} catch (err if err instanceof StopIteration) {
document.write("End of record.<br>\n");
}
在 JavaScript 1.8 中,你可以規避要重建生成器函數的麻煩,而使用一個生成器表達式來代替:
let it = (i + 3 for (i in someObj));
try {
while (true) {
document.write(it.next() + "<br>\n");
}
} catch (err if err instanceof StopIteration) {
document.write("End of record.<br>\n");
}
生成器表達式也可以像數值那樣被傳給一個函數。非常值得注意的是,生成器在絕對必要的有用的時候才被運行(並不像典型的數組概念的條件那樣,預先搭好數組的結構)。這個區別可以從下面的例子中看到:
使用JavaScript 1.7 數組理念
handleResults([ i for ( i in obj ) if ( i > 3 ) ]);
function handleResults( results ) {
for ( let i in results )
// ...
}
使用 JavaScript 1.8 的生成器表達式
handleResults( i for ( i in obj ) if ( i > 3 ) );
function handleResults( results ) {
for ( let i in results )
// ...
}
這兩個例子之間最大的區別就是,使用生成器表達式的時候,只需要循環那個 'obj' 結構一次,總共;而在第一個例子中,將會在遞歸的時候再循環一次。
JavaScript 1.8.1
JavaScript 1.8.1包含在Gecko1.9.1(將整合到Firefox3.5中)中。該版本只有很少的更新,主要集中在添加實時編譯跟蹤,參見:Tracemonkey just-in-time compiler。
當然其中較為顯著的改變是移除了API中的callback分支,替換了callback操作,參見:detailed in this newsgroup posting。
添加的部分
Object.getPrototypeOf()
This new method returns the prototype of a specified object.
該方法將返回指定對象的原型。
New trim methods on the String object
The String object now has trim(), trimLeft(), and trimRight() methods.
String對象現在將具有trim(),trimLeft(),和trimRight()方法。
XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved