成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

javascript變量運(yùn)算符詳解

Sourcelink / 2000人閱讀

摘要:代碼示例等號檢查,類型轉(zhuǎn)換后返回全等檢查,由于時(shí)類型,時(shí)類型,類型不同,返回關(guān)系運(yùn)算符關(guān)系運(yùn)算符執(zhí)行的是比較運(yùn)算,通常用于判斷兩個(gè)變量哪個(gè)大哪個(gè)小關(guān)系運(yùn)算符都返回一個(gè)布爾值。邏輯或運(yùn)輸符用雙豎線表示。

1.運(yùn)算符

JavaScript中常見的運(yùn)算符包含:賦值運(yùn)算符、算數(shù)運(yùn)算符、等性運(yùn)算符、關(guān)系運(yùn)算符、條件運(yùn)算符、布爾運(yùn)算符、邏輯運(yùn)算符……

1.賦值運(yùn)算符 =

賦值運(yùn)算符“=”,用于給某個(gè)變量賦值。

代碼示例:

var x;
x=5;        //把數(shù)字 5 賦值給變量x
x="hello";  //把字符串 hello 賦值給x

除了簡單的賦值運(yùn)算符“=”之外,還有一種常用的復(fù)合賦值運(yùn)算符

1.1 加法/賦值運(yùn)算符 +=

加法賦值運(yùn)算符x+=y,等價(jià)于x=x+y,它是一種簡寫形式。

代碼示例:

var x=5;
x+=1;           //等價(jià)于  x=x+1;
console.log(x);     //6
1.2 減法/賦值運(yùn)算符 -=

減法賦值運(yùn)算符x-=y,等價(jià)于x=x-y,它是一種簡寫形式。

代碼示例:

var x=5;
x-=1;           //等價(jià)于  x=x-1;
console.log(x);     //4
2.算數(shù)運(yùn)算符

JavaScript中的算數(shù)運(yùn)算符主要用在數(shù)字類型變量的數(shù)學(xué)運(yùn)算,包含加法、減法、乘法、除法、取余等等。

代碼示例:

var x=5,y=2;
console.log(x+y);    //加法運(yùn)算,結(jié)果:7      
console.log(x-y);    //減法運(yùn)算,結(jié)果:3  
console.log(x*y);    //乘法運(yùn)算,結(jié)果:10
console.log(x/z);    //除法運(yùn)算,結(jié)果:2.5
console.log(x%y);    //取余運(yùn)算,結(jié)果:1,   5除以2,商為2,余數(shù)為1  
3.等性運(yùn)算符

等性運(yùn)算符主要用于判斷兩個(gè)變量的值和類型是否相等。判斷返回的結(jié)果為一個(gè)布爾值。

3.1等號和非等號

在JavaScript中等號由雙等號(==)表示,當(dāng)雙等號兩邊運(yùn)算數(shù)相等時(shí),返回結(jié)果為true。

代碼示例:

var x=5,y=5,z=9;
console.log(x==y);      //true
console.log(x==z);      //false

非等號由感嘆號加等號(!=)表示,當(dāng)非等號兩邊的運(yùn)算數(shù)不相等時(shí),返回結(jié)果為true。

代碼示例:

var x=5,y=5,z=9;
console.log(x!=y);      //false
console.log(x!=z);      //true

注意:在比較兩個(gè)運(yùn)算數(shù)是否相等時(shí),JavaScript引擎會將這兩個(gè)運(yùn)算數(shù)進(jìn)行類型轉(zhuǎn)換

執(zhí)行類型轉(zhuǎn)換的規(guī)則如下:

布爾值轉(zhuǎn)換成數(shù)字:false轉(zhuǎn)換成0,true轉(zhuǎn)換成1.

數(shù)字與字符串:字符串轉(zhuǎn)換成數(shù)字。

對象與字符串:把對象轉(zhuǎn)換成字符串。

對象與數(shù)組:把對象轉(zhuǎn)換成數(shù)組。

在比較時(shí),對于一些特殊的運(yùn)算數(shù),遵守以下規(guī)則:

null和undefined相等。

不能把null和undefined轉(zhuǎn)換成其他值。

只要有一個(gè)運(yùn)算數(shù)是NaN,等號返回false,非等號返回true。

如果兩個(gè)運(yùn)算數(shù)都是對象,比較的是他們的引用值。

如果兩個(gè)運(yùn)算數(shù)指向同一對象,等號返回true。

即使兩個(gè)數(shù)都是NaN,等號仍然返回false。

特殊的情況:

表達(dá)式 返回值
null == undefined true
"NaN" == NaN false
5 == NaN false
NaN == NaN false
NaN !=NaN true
false == 0 true
true == 1 true
true == 2 false
undefined == 0 false
null == 0 false
"5" == 5 true
3.2全等號和非全等號

全等號和非全等號所做的事與等號和非等號相同,只是在檢查相等性前,不執(zhí)行類型轉(zhuǎn)換

全等號由三個(gè)等號表示(===),檢查時(shí)不僅要值相等,更要類型相等。

代碼示例:

var x=5;
var y="5";
console.log(x==y);      //等號檢查,類型轉(zhuǎn)換后返回 true
console.log(x===y);     //全等檢查,由于x時(shí)number類型,y時(shí)string類型,類型不同,返回false
4.關(guān)系運(yùn)算符

關(guān)系運(yùn)算符執(zhí)行的是比較運(yùn)算,通常用于判斷兩個(gè)變量哪個(gè)大?哪個(gè)???關(guān)系運(yùn)算符都返回一個(gè)布爾值。

常用的關(guān)系運(yùn)算符有大于(>)、小于(<)、大于等于(>=)、小于等于(<=)

代碼示例:

var x=5,y=3,z=5;
console.log(x>y);       //true
console.log(x=z);      //true
console.log(x<=z);      //true
4.1字符串與字符串之間的關(guān)系比較

對于數(shù)字類型的變量關(guān)系比較我們遵循數(shù)學(xué)原則,但是對于字符串類型的變量,如去要進(jìn)行關(guān)系比較則需按照ASCII碼;

ASCII碼對照表見下圖:

代碼示例:

var x="Hello",x="world";
console.log(x>y);       //false

如上述代碼所示,如果我們要比較Hello和world這兩個(gè)字符串,首先比較首字符的大小,對照ASCII字符編碼表,H的十進(jìn)制編碼為72,w的十進(jìn)制編碼為119,所以變量x應(yīng)該是小于變量y,故而上面代碼返回結(jié)果為false。

4.2數(shù)字與字符串之間的關(guān)系比較

當(dāng)一個(gè)字符串與數(shù)字進(jìn)行關(guān)系比較時(shí),JavaScript引擎會將字符串轉(zhuǎn)換成數(shù)字,然后按照數(shù)字順序比較它們。

代碼示例:

var x="30",y=5;
console(x>y);       //true

在上述示例代碼中,字符串"30"將被轉(zhuǎn)換成數(shù)字30,然后與數(shù)字5進(jìn)行比較。

但是,如果字符串不能轉(zhuǎn)換成數(shù)字又該如何呢?

var x="hello",y=9;
console.log(x>y);   //false

字符串"hello"不能轉(zhuǎn)換成有意義的數(shù)字,所以在類型轉(zhuǎn)換的時(shí)候返回的是NaN。
==任何包含NaN的關(guān)系運(yùn)算都要返回false==,因此上述代碼也輸出false。

5.條件運(yùn)算符(三元運(yùn)算符)

條件運(yùn)算符又稱為三元運(yùn)算符,它在JavaScript中是一個(gè)既有比較又有賦值的運(yùn)算符。語法如下:

var x=booleanExpressin ? trueValue : falseValue;

該運(yùn)算符的意思是:根據(jù)booleanExpressin條件表達(dá)式的計(jì)算結(jié)果,如果條件表達(dá)式返回的結(jié)果為true,則把trueValue賦值給x,如果條件表達(dá)式返回的結(jié)果為false,則把falseValue賦值給變量。

代碼示例:

var x=5,y=10;
var z=(x>y)?x:y;
console.log(z);     //10
6.邏輯運(yùn)算符

JavaScript中的邏輯運(yùn)算符有三種:NOT(取反)、AND(邏輯與)和OR(邏輯或)

在進(jìn)行邏輯運(yùn)算之前,JavaScript會將變量轉(zhuǎn)換成布爾類型。因此我們需要了解一下不同類型的變量轉(zhuǎn)換為布爾類型時(shí)的邏輯值:

參數(shù) 說明 轉(zhuǎn)換結(jié)果
"" 空字符串 false
"hello" 非空字符串 true
" " 空格 true
0 數(shù)字0 false
5.5 非零正數(shù) true
-4 非零負(fù)數(shù) true
null false
NaN false
undefined false
Object 對象 true
Array 數(shù)組 true
6.1 NOT 取反

邏輯 NOT 取反運(yùn)算符,意思是得到與當(dāng)前參數(shù)相反的結(jié)果,由感嘆號(!)表示,取反運(yùn)算符返回的一定是布爾值。

注意:如果運(yùn)算數(shù)是undefined,發(fā)生錯(cuò)誤。

代碼示例:

var bFalse = false;
var sRed = "red";
var iZero = 0;
var iThreeFourFive = 345;
var oObject = new Object();

console.log(!bFalse);   //true
console.log(!sRed);   //false
console.log(!iZero);   //true
console.log(!iThreeFourFive);   //false
console.log(!oObject);   //false
6.2 AND 邏輯與

邏輯與AND運(yùn)算符,進(jìn)行運(yùn)算時(shí)需要兩個(gè)參數(shù),只有當(dāng)兩個(gè)參數(shù)轉(zhuǎn)換都為true時(shí),邏輯與才返回true。邏輯與AND運(yùn)輸符用雙和號(&&)表示。

代碼示例:

var x=true,y=false;
console.log(x&&y);  //false

注意:邏輯與AND運(yùn)算的運(yùn)算數(shù)可以是任何類型的,如果某個(gè)運(yùn)算數(shù)不是原始的布爾類型,邏輯與AND運(yùn)算不一定返回布爾值:

如果一個(gè)運(yùn)算數(shù)是對象,另一個(gè)是 Boolean 值,返回該對象。

如果兩個(gè)運(yùn)算數(shù)都是對象,返回第二個(gè)對象。

如果某個(gè)運(yùn)算數(shù)是 null,返回 null。

如果某個(gè)運(yùn)算數(shù)是 NaN,返回 NaN。

如果某個(gè)運(yùn)算數(shù)是 undefined,發(fā)生錯(cuò)誤。

6.3 OR 邏輯或

邏輯或OR運(yùn)算符,進(jìn)行運(yùn)算時(shí)需要兩個(gè)參數(shù),只要當(dāng)兩個(gè)參數(shù)中其中一個(gè)為true時(shí),邏輯與返回true。邏輯或OR運(yùn)輸符用雙豎線(||)表示。

代碼示例:

var x=true,y=false;
console.log(x||y);  //true

注意:邏輯或 OR 與邏輯與 AND 運(yùn)算符相似,如果某個(gè)運(yùn)算數(shù)不是 Boolean 值,邏輯 OR 運(yùn)算并不一定返回 Boolean 值:

如果一個(gè)運(yùn)算數(shù)是對象,并且該對象左邊的運(yùn)算數(shù)值均為 false,則返回該對象。

如果兩個(gè)運(yùn)算數(shù)都是對象,返回第一個(gè)對象。

如果最后一個(gè)運(yùn)算數(shù)是 null,并且其他運(yùn)算數(shù)值均為 false,則返回 null。

如果最后一個(gè)運(yùn)算數(shù)是 NaN,并且其他運(yùn)算數(shù)值均為 false,則返回 NaN。

如果某個(gè)運(yùn)算數(shù)是 undefined,發(fā)生錯(cuò)誤。

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/96255.html

相關(guān)文章

  • 【連載】前端個(gè)人文章整理-從基礎(chǔ)到入門

    摘要:個(gè)人前端文章整理從最開始萌生寫文章的想法,到著手開始寫,再到現(xiàn)在已經(jīng)一年的時(shí)間了,由于工作比較忙,更新緩慢,后面還是會繼更新,現(xiàn)將已經(jīng)寫好的文章整理一個(gè)目錄,方便更多的小伙伴去學(xué)習(xí)。 showImg(https://segmentfault.com/img/remote/1460000017490740?w=1920&h=1080); 個(gè)人前端文章整理 從最開始萌生寫文章的想法,到著手...

    madthumb 評論0 收藏0
  • js幾個(gè)經(jīng)典的題目詳解

    摘要:四這個(gè)題目比較簡單即函數(shù)聲明和變量聲明的關(guān)系和影響,遇到同名的函數(shù)聲明,不會重新定義五關(guān)于這個(gè)題目,的規(guī)范有解釋的。屬性的值是對象關(guān)于對象的具體定義,看這里對象六這個(gè)題目可以說是最簡單的,也是最詭異的關(guān)于這個(gè)題目,我們先來了解個(gè)概念。 廢話不多說,直接看題目,先不要急著看答案 先自己思考,收獲更多 (長期補(bǔ)倉); 一 var out = 25, inner = { ...

    stormgens 評論0 收藏0
  • JavaScript深入淺出

    摘要:理解的函數(shù)基礎(chǔ)要搞好深入淺出原型使用原型模型,雖然這經(jīng)常被當(dāng)作缺點(diǎn)提及,但是只要善于運(yùn)用,其實(shí)基于原型的繼承模型比傳統(tǒng)的類繼承還要強(qiáng)大。中文指南基本操作指南二繼續(xù)熟悉的幾對方法,包括,,。商業(yè)轉(zhuǎn)載請聯(lián)系作者獲得授權(quán),非商業(yè)轉(zhuǎn)載請注明出處。 怎樣使用 this 因?yàn)楸救藢儆趥吻岸耍虼宋闹兄豢炊?8 成左右,希望能夠給大家?guī)韼椭?...(據(jù)說是阿里的前端妹子寫的) this 的值到底...

    blair 評論0 收藏0
  • JavaScript數(shù)據(jù)類型及(隱式)類型轉(zhuǎn)換詳解

    摘要:顯示的調(diào)用轉(zhuǎn)換過程稱為顯式強(qiáng)制類型轉(zhuǎn)換,隱式的情況稱為隱式強(qiáng)制類型轉(zhuǎn)換。隱式強(qiáng)制類型轉(zhuǎn)換讓代碼變得晦澀難懂而又便捷而奇妙。事實(shí)上,允許在比較中進(jìn)行強(qiáng)制類型轉(zhuǎn)換,而不允許。如果有并且返回基本類型值,就使用該值進(jìn)行強(qiáng)制類型轉(zhuǎn)換。 JavaScript是一種非常靈活的現(xiàn)代編程語言,靈活到使用者極其容易被忽視的它那廣闊的世界以及它帶給我們的無限遐想空間。本文將對JavaScript最最基礎(chǔ)也最...

    hiyayiji 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<