|
使用 JavaScript 1.8
為了可以在HTML中使用 JavaScript 1.8 的新特性,需要如下這樣寫:
<script type="application/Javascript;version=1.8"> ... 你的代碼 ... </script>
在使用 JavaScript shell 、JavaScript XPCOM 組件,或者 XUL <script> 元素的時(shí)候,就是自動(dòng)使用最新的JS版本(Mozilla 1.9中的 JS1.8)。
如果需要使用新的關(guān)鍵字 "yield" 和 "let" 的話,你就要指定是1.7版本或者更高的版本,因?yàn)橐呀?jīng)寫好的那些代碼可能會(huì)把這兩個(gè)關(guān)鍵字用作變量名或者函數(shù)名。如果并沒(méi)有使用任何新的關(guān)鍵字,就可以不用指定JavaScript的版本。
表達(dá)式閉包
這個(gè)新添加的特性其實(shí)就是簡(jiǎn)單函數(shù)的方便寫法,使得這個(gè)語(yǔ)言更加類似典型的Lambda notation.
JavaScript 1.7 以及更老的版本:
function(x) { return x * x; }
JavaScript 1.8:
function(x) x * x
這個(gè)語(yǔ)法允許你省略花括號(hào)和 'return' 語(yǔ)句 -- 隱式的做它們的工作。用這種方法寫,就只是表面上看起來(lái)短了一些,并沒(méi)有其他好處。
示例:
綁定事件處理器的簡(jiǎn)單寫法:
document.addEventListener("click", function() false, true);
把這個(gè)定義與JavaScript 1.6中的一寫數(shù)組函數(shù)一起使用:
elems.some(function(elem) elem.type == "text");
生成器表達(dá)式
這個(gè)新添加的特性,允許你簡(jiǎn)單的創(chuàng)建生成器(在JavaScript 1.7引入的)。通常你以前需要?jiǎng)?chuàng)建一個(gè)自定義的函數(shù),它含有一個(gè) yield,但是這個(gè)新特性使你可以使用類似數(shù)組概念的語(yǔ)法來(lái)創(chuàng)建一個(gè)獨(dú)立的生成器句柄。
在 JavaScript 1.7 中,你可能需要寫出想下面這樣的代碼來(lái)為一個(gè)對(duì)象創(chuàng)建自定義的生成器:
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 中,你可以規(guī)避要重建生成器函數(shù)的麻煩,而使用一個(gè)生成器表達(dá)式來(lái)代替:
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");
}
生成器表達(dá)式也可以像數(shù)值那樣被傳給一個(gè)函數(shù)。非常值得注意的是,生成器在絕對(duì)必要的有用的時(shí)候才被運(yùn)行(并不像典型的數(shù)組概念的條件那樣,預(yù)先搭好數(shù)組的結(jié)構(gòu))。這個(gè)區(qū)別可以從下面的例子中看到:
使用JavaScript 1.7 數(shù)組理念
handleResults([ i for ( i in obj ) if ( i > 3 ) ]);
function handleResults( results ) {
for ( let i in results )
// ...
}
使用 JavaScript 1.8 的生成器表達(dá)式
handleResults( i for ( i in obj ) if ( i > 3 ) );
function handleResults( results ) {
for ( let i in results )
// ...
}
這兩個(gè)例子之間最大的區(qū)別就是,使用生成器表達(dá)式的時(shí)候,只需要循環(huán)那個(gè) 'obj' 結(jié)構(gòu)一次,總共;而在第一個(gè)例子中,將會(huì)在遞歸的時(shí)候再循環(huán)一次。
JavaScript 1.8.1
JavaScript 1.8.1包含在Gecko1.9.1(將整合到Firefox3.5中)中。該版本只有很少的更新,主要集中在添加實(shí)時(shí)編譯跟蹤,參見(jiàn):Tracemonkey just-in-time compiler。
當(dāng)然其中較為顯著的改變是移除了API中的callback分支,替換了callback操作,參見(jiàn):detailed in this newsgroup posting。
添加的部分
Object.getPrototypeOf()
This new method returns the prototype of a specified object.
該方法將返回指定對(duì)象的原型。
New trim methods on the String object
The String object now has trim(), trimLeft(), and trimRight() methods.
String對(duì)象現(xiàn)在將具有trim(),trimLeft(),和trimRight()方法。
JavaScript技術(shù):W3C Group的JavaScript1.8 新特性介紹,轉(zhuǎn)載需保留來(lái)源!
鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。