欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JavaScript高級程序設計閱讀筆記(五) ECMAScript中的運算符(一)

 更新時間:2012年02月27日 23:38:21   作者:  
ECMAScript中的運算符,學習js的朋友可以看看
2.9 運算符
2.9.1、一元運算符
  一元運算符只有一個參數(shù),即要操作的對象或值。

  1、delete:刪除對以前定義的對象屬性或方法的引用,但此運算符不能刪除開發(fā)者未定義的屬性和方法。示例:
復制代碼 代碼如下:

var o=new Object;
o.name="Nicholas";
o.show=function(){
return "test";
};
console.log(o.name); //outpus Nicholas
console.log(o.show()); //outpus test

delete o.name;
delete o.show;

console.log(o.name); //outpus undefined
console.log(o.show()); //outpus TypeError: o.show is not a function

delete o.toString;
console.log(o.toString()); //outpus [object Object]

2、void:對任何值都返回undefined,該運算符通常用于避免輸出不應該輸出的值。

  如在鏈接中打開新窗口,代碼如下:

<a href="javascript:window.open('about:blank')">Click Me</a>
  點擊鏈接后會在新窗口中出現(xiàn)[object]。這是因為window.open()方法返回了對新打開窗口的引用。然后該對象將被轉換成要顯示的字符串。要避免這種結果,可以用void運算符調(diào)用window.open()函數(shù):

<a href="javascript:void(window.open('about:blank'))">Click Me</a>
  3、前增量/前減量運算符:從C中借用的兩個運算符。示例:
復制代碼 代碼如下:

var iNum=10;
console.log(++iNum); //outpus 11 same as iNum=iNum+1
console.log(iNum); //outpus 11
console.log(--iNum); //outpus 10 same as iNum=iNum-1
console.log(iNum); //outpus 10

4、后增量/后減量運算符:從C中借用的兩個運算符。與前增量/前減量一樣,也是給數(shù)值加1或減1,不同的是后綴式運算符是在計算過包含它們的表達式后才進行增量或減量運算的。示例:
復制代碼 代碼如下:

var iNum=10;
iNum--
console.log(iNum); //outpus 9
console.log(iNum--); //outpus 9
console.log(iNum); //outpus 8
iNum++
console.log(iNum); //outpus 9
console.log(iNum++); //outpus 9
console.log(iNum); //outpus 10

 5、一元加法和一元減法:用法與高中數(shù)學中學到的用法相同,一元加法對數(shù)字無任何影響,一元減法就是對數(shù)值求負。但一元回法和一元減法對字符串進行運算時與parseInt()相似,主要的不同是只有對以"ox"開頭的字符串,一元運算符才把它轉換為10進制的值。示例:
復制代碼 代碼如下:

var iNum=25;
iNum=+iNum;
console.log(iNum); //outpus 25

var sNum="50";
console.log(typeof sNum); //outpus string
console.log(+sNum); //outpus 50
console.log(typeof +sNum); //outpus number

var sNum1="017";
var sNum2="0xB";
console.log(-sNum1); //outpus -17
console.log(-sNum2); //outpus -11

2.9.2 位運算符
  1、位運算NOT:由(~)表示,處理過程如下:

  (1) 把運算數(shù)轉換為32位數(shù)字

  (2) 把二進制形式轉換成它的二進制反碼;

  (3) 把二進制反碼轉換為浮點數(shù)

  示例:

復制代碼 代碼如下:

var iNum1=25; //25 is equal to 0000 0000 0000 0000 0000 0000 0001 1001
var iNum2=~iNum1; //conver to 1111 1111 1111 1111 1111 1111 1110 0110
console.log(iNum2); //outpus -26

//位運算符NOT實質(zhì)上是對數(shù)字求負,然后減1,因此下面的代碼也可以得到同樣的效果
var iNum3=25;
var iNum4=-iNum3-1;
console.log(iNum4);

2、位運算AND:由(&)表示,直接對數(shù)字的二進制形式進行計算。規(guī)則為全為1才為1,否則為0。示例:
復制代碼 代碼如下:

var iNum1=25; //25 is equal to 0000 0000 0000 0000 0000 0000 0001 1001
var iNum2=iNum1&3; // 3 is equal to 0000 0000 0000 0000 0000 0000 0000 0011
console.log(iNum2); // and is 0000 0000 0000 0000 0000 0000 0000 0001 outpus 1

  3、位運算OR:由(|)表示,直接對數(shù)字的二進制形式進行計算。規(guī)則為全為0才為0,否則為1。示例:
復制代碼 代碼如下:

var iNum1=25; //25 is equal to 0000 0000 0000 0000 0000 0000 0001 1001
var iNum2=iNum1|3; // 3 is equal to 0000 0000 0000 0000 0000 0000 0000 0011

  4、位運算XOR:由(^)表示,直接對數(shù)字的二進制形式進行計算。規(guī)則為只有一個數(shù)位存放的是1時才為1,否則為0。示例:
復制代碼 代碼如下:

var iNum1=25; //25 is equal to 0000 0000 0000 0000 0000 0000 0001 1001
var iNum2=iNum1^3; // 3 is equal to 0000 0000 0000 0000 0000 0000 0000 0011
console.log(iNum2); // xor is 0000 0000 0000 0000 0000 0000 0001 1010 outpus 26

  5、左移運算:由(<<)表示,把數(shù)字中的所有數(shù)位向左移動指定的數(shù)量,保留符號位,左移一位相當于乘以2。
  6、有符號右移運算:由(>>)表示,把數(shù)字中的所有數(shù)位向右移動指定的數(shù)量,保留符號位,右移一位相當于除以2。
  7、無符號右移運算:由(>>>)表示,把數(shù)字中的所有數(shù)位向右移動指定的數(shù)量。對于正數(shù)跟有符號的右移完全一樣,對于負數(shù)作為正數(shù)來處理。
  示例:
復制代碼 代碼如下:

var iOld=2;
var iOld1=64;
var iOld2=64;
var iOld3=-2;
var iNew=iOld<<5;
var iNew1=iOld1>>5;
var iNew2=iOld2>>>5;
var iNew3=iOld3>>>1;
console.log(iNew); //outpus 64
console.log(iNew1); //outpus 2
console.log(iNew2); //outpus 2
console.log(iNew3); //outpus 2147483647

  負數(shù)iOld3無符號右移的計算方法如下:
  先把-2轉換成無符號的等價形式,即-2的二進制補碼:
  -2的非負版本二進制表示:0000 0000 0000 0000 0000 0000 0000 0010
  該二進制的反碼:1111 1111 1111 1111 1111 1111 1111 1101
  在二進制反碼上加1:1111 1111 1111 1111 1111 1111 1111 1110
  最后再右移一位:0111 1111 1111 1111 1111 1111 1111 1111 即為:2147483647
2.9.3 Boolean運算符
  1、邏輯NOT:由(!)表示,返回值一定是Boolean值,行為如下:
  如果運算數(shù)是對象,返回false
  如果運算數(shù)是數(shù)字0,運回true
  如果運算數(shù)是0以外的任何數(shù)字,反回false
  如果運算數(shù)是null,返回true
  如果運算數(shù)是NaN,返回true
  如果運算數(shù)是undefined,發(fā)生錯誤
  2、邏輯AND:由(&&)表示,如果運算數(shù)均為Boolean型,只有當運算數(shù)均為true時才返回true,否則返回false。AND運算的運算數(shù)可以是任何類型,返回值不一定是Boolean值:
  如果一個運算數(shù)是對象,另一個是Boolean值,返回該對象
  如果兩個運算數(shù)都是對象,返回第二個對象
  如果某個運算數(shù)是null,返回null
  如果某個運算數(shù)是NaN,返回NaN
  如果某個運算數(shù)是undefined,發(fā)生錯誤
  ECMAScript中的邏輯AND也是簡便運算,即如果第一個運算數(shù)決定了結果,就不再計算第二個運算數(shù),示例:
復制代碼 代碼如下:

var bFalse=false;
var bResult=bFalse&&bUnknow;
console.log(bResult); //outpus false
var bTrue=true;
var bResult=bTrue&&bUnknow;
console.log(bResult); //outpus ReferenceError: bUnknow is not defined

  3、邏輯OR運算符:由(||)表示,如果運算數(shù)均為Boolean型,只有當運算數(shù)均為false時才返回false,否則返回true。OR運算的運算數(shù)可以是任何類型,返回值不一定是Boolean值:
  如果一個運算數(shù)是對象,另一個是Boolean值,返回該對象
  如果兩個運算數(shù)都是對象,返回第一個對象
  如果某個運算數(shù)是null,返回null
  如果某個運算數(shù)是NaN,返回NaN
  如果某個運算數(shù)是undefined,發(fā)生錯誤
  ECMAScript中的邏輯OR也是簡便運算,即如果第一個運算數(shù)決定了結果,就不再計算第二個運算數(shù),示例:
復制代碼 代碼如下:

var bTrue=true;
var bResult=bTrue||bUnknow;
console.log(bResult); //outpus true
var bFalse=false;
var bResult=bFalse||bUnknow;
console.log(bResult); //outpus ReferenceError: bUnknow is not defined

2.9.4 乘性運算符
  1、乘法運算符:由(*)表示,正常情況下跟數(shù)學中的乘法相同,特殊情況下有些特殊值:
  如果運算的結果太大或太小,生成結果為Infinity或-Infinity
  如果某個運算數(shù)是NaN,結果為NaN
  Infinity乘以0,結果為NaN
  Infinity乘以0以外的任何數(shù)字,結果為Infinity或-Infinity,由第二個運算數(shù)的符號決定
  Infinity乘以Infinity,結果為Infinity
  2、除法運算符:由(/)表示,正常情況下跟數(shù)學中的乘法相同,特殊情況下有些特殊值:
  如果運算的結果太大或太小,生成結果為Infinity或-Infinity
  如果某個運算數(shù)是NaN,結果為NaN
  Infinity被Infinity除,結果為NaN
  Infinity被任何數(shù)字除,結果為Infinity
  0除以一個非無窮大的數(shù)字,結果為NaN
  Infinity被0以外的任何數(shù)字除,結果為Infinity或-Infinity,由第二個運算數(shù)的符號決定
  3、取模運算符:由(%)表示,正常情況下跟數(shù)學中的乘法相同,特殊情況下有些特殊值:
  如果被除數(shù)是Infinity,或者除數(shù)是0,結果為NaN
  Infinity被Infinity除,結果為NaN
  如果除數(shù)是無窮大的數(shù),結果為被除數(shù)
  如果被除數(shù)為0,結果為0

相關文章

  • 微信小程序實現(xiàn)活動報名登記功能(實例代碼)

    微信小程序實現(xiàn)活動報名登記功能(實例代碼)

    這篇文章主要介紹了微信小程序實現(xiàn)活動報名登記,本篇將介紹使用微信小程序實現(xiàn)發(fā)起一個活動報名的設計,以此為基礎,我們可以掌握微信小程序表單的基本用法,進而在諸如疫情信息登記、出入報備等場景中使用小程序進行開發(fā),滿足相關的需求,需要的朋友可以參考下
    2022-09-09
  • JS實現(xiàn)文件動態(tài)順序載入的方法

    JS實現(xiàn)文件動態(tài)順序載入的方法

    這篇文章主要介紹了JS實現(xiàn)文件動態(tài)順序載入的方法,實例分析了基于Mootools框架實現(xiàn)動態(tài)載入的技巧,具有一定參考借鑒價值,需要的朋友可以參考下
    2015-03-03
  • Lab.js初次使用筆記

    Lab.js初次使用筆記

    這篇文章主要介紹了Lab.js初次使用筆記,本文對比了普通動態(tài)加載JS文件的技術和使用Lab.js加載JS文件的技術,并給出了Lab.js加載示例,需要的朋友可以參考下
    2015-02-02
  • filemanage功能中用到的common.js

    filemanage功能中用到的common.js

    filemanage功能中用到的common.js...
    2007-04-04
  • bootstrap table支持高度百分比的實例代碼

    bootstrap table支持高度百分比的實例代碼

    這篇文章給大家介紹了bootstrap table支持高度百分比的實例代碼,通過更改BootstrapTable.prototype.resetView 方法,以支持高度百分比定義,適應不同高度屏幕,感興趣的朋友跟隨腳本之家小編一起學習吧
    2018-02-02
  • 原生JS面向對象實現(xiàn)打字小游戲

    原生JS面向對象實現(xiàn)打字小游戲

    這篇文章主要為大家詳細介紹了原生JS面向對象實現(xiàn)打字小游戲,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-09-09
  • 詳解如何使用微信小程序云函數(shù)發(fā)送短信驗證碼

    詳解如何使用微信小程序云函數(shù)發(fā)送短信驗證碼

    這篇文章主要介紹了詳解如何使用微信小程序云函數(shù)發(fā)送短信驗證碼,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-03-03
  • 每個 JavaScript 工程師都應懂的33個概念

    每個 JavaScript 工程師都應懂的33個概念

    這個項目是為了幫助開發(fā)者掌握 JavaScript 概念而創(chuàng)立的。它不是必備,但在未來學習( JavaScript )中,可以作為一篇指南,需要的朋友可以參考下
    2018-10-10
  • js Element Traversal規(guī)范中的元素遍歷方法

    js Element Traversal規(guī)范中的元素遍歷方法

    對于元素間的空格,在IE9之前,都不會返回文檔節(jié)點,其它的所有瀏覽器都會返回文檔節(jié)點,為了兼容瀏覽器這間的差異,又不更改已有的DOM 標準,所以有了 Element Traversal 規(guī)范
    2018-04-04
  • js 鼠標點擊事件及其它捕獲

    js 鼠標點擊事件及其它捕獲

    這段代碼是用來做,點擊一個按紐打開個div,在頁面空白處點擊鼠標隱藏這個div
    2009-06-06

最新評論