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

JavaScript高級(jí)程序設(shè)計(jì)閱讀筆記(五) ECMAScript中的運(yùn)算符(一)

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

  1、delete:刪除對(duì)以前定義的對(duì)象屬性或方法的引用,但此運(yùn)算符不能刪除開(kāi)發(fā)者未定義的屬性和方法。示例:
復(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:對(duì)任何值都返回undefined,該運(yùn)算符通常用于避免輸出不應(yīng)該輸出的值。

  如在鏈接中打開(kāi)新窗口,代碼如下:

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

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

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、后增量/后減量運(yùn)算符:從C中借用的兩個(gè)運(yùn)算符。與前增量/前減量一樣,也是給數(shù)值加1或減1,不同的是后綴式運(yùn)算符是在計(jì)算過(guò)包含它們的表達(dá)式后才進(jìn)行增量或減量運(yùn)算的。示例:
復(fù)制代碼 代碼如下:

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ù)學(xué)中學(xué)到的用法相同,一元加法對(duì)數(shù)字無(wú)任何影響,一元減法就是對(duì)數(shù)值求負(fù)。但一元回法和一元減法對(duì)字符串進(jìn)行運(yùn)算時(shí)與parseInt()相似,主要的不同是只有對(duì)以"ox"開(kāi)頭的字符串,一元運(yùn)算符才把它轉(zhuǎn)換為10進(jìn)制的值。示例:
復(fù)制代碼 代碼如下:

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 位運(yùn)算符
  1、位運(yùn)算NOT:由(~)表示,處理過(guò)程如下:

  (1) 把運(yùn)算數(shù)轉(zhuǎn)換為32位數(shù)字

  (2) 把二進(jìn)制形式轉(zhuǎn)換成它的二進(jìn)制反碼;

  (3) 把二進(jìn)制反碼轉(zhuǎn)換為浮點(diǎn)數(shù)

  示例:

復(fù)制代碼 代碼如下:

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

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

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

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、位運(yùn)算OR:由(|)表示,直接對(duì)數(shù)字的二進(jìn)制形式進(jìn)行計(jì)算。規(guī)則為全為0才為0,否則為1。示例:
復(fù)制代碼 代碼如下:

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、位運(yùn)算XOR:由(^)表示,直接對(duì)數(shù)字的二進(jìn)制形式進(jìn)行計(jì)算。規(guī)則為只有一個(gè)數(shù)位存放的是1時(shí)才為1,否則為0。示例:
復(fù)制代碼 代碼如下:

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、左移運(yùn)算:由(<<)表示,把數(shù)字中的所有數(shù)位向左移動(dòng)指定的數(shù)量,保留符號(hào)位,左移一位相當(dāng)于乘以2。
  6、有符號(hào)右移運(yùn)算:由(>>)表示,把數(shù)字中的所有數(shù)位向右移動(dòng)指定的數(shù)量,保留符號(hào)位,右移一位相當(dāng)于除以2。
  7、無(wú)符號(hào)右移運(yùn)算:由(>>>)表示,把數(shù)字中的所有數(shù)位向右移動(dòng)指定的數(shù)量。對(duì)于正數(shù)跟有符號(hào)的右移完全一樣,對(duì)于負(fù)數(shù)作為正數(shù)來(lái)處理。
  示例:
復(fù)制代碼 代碼如下:

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

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

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運(yùn)算符:由(||)表示,如果運(yùn)算數(shù)均為Boolean型,只有當(dāng)運(yùn)算數(shù)均為false時(shí)才返回false,否則返回true。OR運(yùn)算的運(yùn)算數(shù)可以是任何類(lèi)型,返回值不一定是Boolean值:
  如果一個(gè)運(yùn)算數(shù)是對(duì)象,另一個(gè)是Boolean值,返回該對(duì)象
  如果兩個(gè)運(yùn)算數(shù)都是對(duì)象,返回第一個(gè)對(duì)象
  如果某個(gè)運(yùn)算數(shù)是null,返回null
  如果某個(gè)運(yùn)算數(shù)是NaN,返回NaN
  如果某個(gè)運(yùn)算數(shù)是undefined,發(fā)生錯(cuò)誤
  ECMAScript中的邏輯OR也是簡(jiǎn)便運(yùn)算,即如果第一個(gè)運(yùn)算數(shù)決定了結(jié)果,就不再計(jì)算第二個(gè)運(yùn)算數(shù),示例:
復(fù)制代碼 代碼如下:

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 乘性運(yùn)算符
  1、乘法運(yùn)算符:由(*)表示,正常情況下跟數(shù)學(xué)中的乘法相同,特殊情況下有些特殊值:
  如果運(yùn)算的結(jié)果太大或太小,生成結(jié)果為Infinity或-Infinity
  如果某個(gè)運(yùn)算數(shù)是NaN,結(jié)果為NaN
  Infinity乘以0,結(jié)果為NaN
  Infinity乘以0以外的任何數(shù)字,結(jié)果為Infinity或-Infinity,由第二個(gè)運(yùn)算數(shù)的符號(hào)決定
  Infinity乘以Infinity,結(jié)果為Infinity
  2、除法運(yùn)算符:由(/)表示,正常情況下跟數(shù)學(xué)中的乘法相同,特殊情況下有些特殊值:
  如果運(yùn)算的結(jié)果太大或太小,生成結(jié)果為Infinity或-Infinity
  如果某個(gè)運(yùn)算數(shù)是NaN,結(jié)果為NaN
  Infinity被Infinity除,結(jié)果為NaN
  Infinity被任何數(shù)字除,結(jié)果為Infinity
  0除以一個(gè)非無(wú)窮大的數(shù)字,結(jié)果為NaN
  Infinity被0以外的任何數(shù)字除,結(jié)果為Infinity或-Infinity,由第二個(gè)運(yùn)算數(shù)的符號(hào)決定
  3、取模運(yùn)算符:由(%)表示,正常情況下跟數(shù)學(xué)中的乘法相同,特殊情況下有些特殊值:
  如果被除數(shù)是Infinity,或者除數(shù)是0,結(jié)果為NaN
  Infinity被Infinity除,結(jié)果為NaN
  如果除數(shù)是無(wú)窮大的數(shù),結(jié)果為被除數(shù)
  如果被除數(shù)為0,結(jié)果為0

相關(guān)文章

  • 微信小程序?qū)崿F(xiàn)活動(dòng)報(bào)名登記功能(實(shí)例代碼)

    微信小程序?qū)崿F(xiàn)活動(dòng)報(bào)名登記功能(實(shí)例代碼)

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

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

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

    Lab.js初次使用筆記

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

    filemanage功能中用到的common.js

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

    bootstrap table支持高度百分比的實(shí)例代碼

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

    原生JS面向?qū)ο髮?shí)現(xiàn)打字小游戲

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

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

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

    每個(gè) JavaScript 工程師都應(yīng)懂的33個(gè)概念

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

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

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

    js 鼠標(biāo)點(diǎn)擊事件及其它捕獲

    這段代碼是用來(lái)做,點(diǎn)擊一個(gè)按紐打開(kāi)個(gè)div,在頁(yè)面空白處點(diǎn)擊鼠標(biāo)隱藏這個(gè)div
    2009-06-06

最新評(píng)論