ECMAScript 一元運算符

一元運算符只有一個參數,即要操做的對象或值。它們是 ECMAScript 中最簡單的運算符。javascript

delete

delete 運算符刪除對之前定義的對象屬性或方法的引用。例如:java

var o = new Object;
o.name = "David";
alert(o.name);	//輸出 "David"

alert(o.name);	//輸出 "undefined"
delete o.name;

在這個例子中,刪除了 name 屬性,意味着強制解除對它的引用,將其設置爲 undefined(即建立的未初始化的變量的值)。瀏覽器

delete 運算符不能刪除開發者未定義的屬性和方法。例如,下面的代碼將引起錯誤:函數

delete o.toString;

即便 toString 是有效的方法名,這行代碼也會引起錯誤,由於 toString() 方法是原始的 ECMAScript 方法,不是開發者定義的。code

void

void 運算符對任何值返回 undefined。該運算符一般用於避免輸出不該該輸出的值,例如,從 HTML 的 <a> 元素調用 JavaScript 函數時。要正確作到這一點,函數不能返回有效值,不然瀏覽器將清空頁面,只顯示函數的結果。例如:對象

<a href="javascript:window.open('about:blank')">Click me</a>

若是把這行代碼放入 HTML 頁面,點擊其中的連接,便可看到屏幕上顯示 "[object]"。TIYblog

這是由於 window.open() 方法返回了新打開的窗口的引用。而後該對象將被轉換成要顯示的字符串。ip

要避免這種效果,能夠用 void 運算符調用 window.open() 函數:開發

<a href="javascript:void(window.open('about:blank'))">Click me</a>

這使 window.open() 調用返回 undefined,它不是有效值,不會顯示在瀏覽器窗口中。字符串

提示:請記住,沒有返回值的函數真正返回的都是 undefined。

前增量/前減量運算符

直接從 C(和 Java)借用的兩個運算符是前增量運算符和前減量運算符。

所謂前增量運算符,就是數值上加 1,形式是在變量前放兩個加號(++):

var iNum = 10;
++iNum;

第二行代碼把 iNum 增長到了 11,它實質上等價於:

var iNum = 10;
iNum = iNum + 1;

一樣,前減量運算符是從數值上減 1,形式是在變量前放兩個減號(--):

var iNum = 10;
--iNum;

在這個例子中,第二行代碼把 iNum 的值減到 9。

在使用前綴式運算符時,注意增量和減量運算符都發生在計算表達式以前。考慮下面的例子:

var iNum = 10;
--iNum;
alert(iNum);	//輸出 "9"
alert(--iNum);	//輸出 "8"
alert(iNum);	//輸出 "8"

第二行代碼對 iNum 進行減量運算,第三行代碼顯示的結果是("9")。第四行代碼又對 iNum 進行減量運算,不過此次前減量運算和輸出操做出如今同一個語句中,顯示的結果是 "8"。爲了證實已實現了全部的減量操做,第五行代碼又輸出一次"8"。

在算術表達式中,前增量和前減量運算符的優先級是相同的,所以要按照從左到右的順序計算之。例如:

var iNum1 = 2;
var iNum2 = 20;
var iNum3 = --iNum1 + ++iNum2;	//等於 "22"
var iNum4 = iNum1 + iNum2;		//等於 "22"

在前面的代碼中,iNum3 等於 22,由於表達式要計算的是 1 + 21。變量 iNum4 也等於 22,也是 1 + 21。

後增量/後減量運算符

還有兩個直接從 C(和 Java)借用的運算符,即後增量運算符和後減量運算符。

後增量運算符也是給數值上加 1,形式是在變量後放兩個加號(++):

var iNum = 10;
iNum++;

不出所料,後減量運算符也是從數值上減 1,形式爲在變量後加兩個減號(--):

var iNum = 10;
iNum--;

第二行代碼把 iNum 的 值減到 9。

與前綴式運算符不一樣的是,後綴式運算符是在計算過包含它們的表達式後才進行增量或減量運算的。考慮如下的例子:

var iNum = 10;
iNum--;
alert(iNum);	//輸出 "9"
alert(iNum--);	//輸出 "9"
alert(iNum);	//輸出 "8"

與前綴式運算符的例子類似,第二行代碼對 iNum 進行減量運算,第三行代碼顯示結果("9")。第四行代碼繼續顯示 iNum 的值,不過此次是在同一語句中應用減量運算符。因爲減量運算髮生在計算過表達式以後,因此這條語句顯示的數是 "9"。執行了第五行代碼後,alert 函數顯示的是 "8",由於在執行第四行代碼以後和執行第五行代碼以前,執行了後減量運算。

在算術表達式中,後增量和後減量運算符的優先級是相同的,所以要按照從左到右的順序計算之。例如:

var iNum1 = 2;
var iNum2 = 20;
var iNum3 = iNum1-- + iNum2++;	//等於 "22"
var iNum4 = iNum1 + iNum2;		//等於 "22"

在前面的代碼中,iNum3 等於 22,由於表達式要計算的是 2 + 20。變量 iNum4 也等於 22,不過它計算的是 1 + 21,由於增量和減量運算都在給 iNum3 賦值後才發生。

一元加法和一元減法

大多數人都熟悉一元加法和一元減法,它們在 ECMAScript 中的用法與您高中數學中學到的用法相同。

一元加法本質上對數字無任何影響:

var iNum = 20;
iNum = +iNum;
alert(iNum);	//輸出 "20"

這段代碼對數字 20 應用了一元加法,返回的仍是 20。

儘管一元加法對數字無做用,但對字符串卻有有趣的效果,會把字符串轉換成數字。

var sNum = "20";
alert(typeof sNum);	//輸出 "string"
var iNum = +sNum;
alert(typeof iNum);	//輸出 "number"

這段代碼把字符串 "20" 轉換成真正的數字。當一元加法運算符對字符串進行操做時,它計算字符串的方式與 parseInt() 類似,主要的不一樣是隻有對以 "0x" 開頭的字符串(表示十六進制數字),一元運算符才能把它轉換成十進制的值。所以,用一元加法轉換 "010",獲得的老是 10,而 "0xB" 將被轉換成 11。

另外一方面,一元減法就是對數值求負(例如把 20 轉換成 -20):

var iNum = 20;
iNum = -iNum;
alert(iNum);	//輸出 "-20"

與一元加法運算符類似,一元減法運算符也會把字符串轉換成近似的數字,此外還會對該值求負。例如:

var sNum = "20";
alert(typeof sNum);	//輸出 "string"
var iNum = -sNum;
alert(iNum);		//輸出 "-20"
alert(typeof iNum);	//輸出 "number"

在上面的代碼中,一元減法運算符將把字符串 "-20" 轉換成 -20(一元減法運算符對十六進制和十進制的處理方式與一元加法運算符類似,只是它還會對該值求負)。

相關文章
相關標籤/搜索