2019-06-6 邏輯運(yùn)算符 與或運(yùn)算 賦值運(yùn)算符 關(guān)系運(yùn)算符

1.邏輯運(yùn)算符

JS中為我們提供了三種邏輯運(yùn)算符

! 非

- !可以用來對一個值進(jìn)行非運(yùn)算

- 所謂非運(yùn)算就是值對一個布爾值進(jìn)行取反操作冰蘑,

true變false,false變true

- 如果對一個值進(jìn)行兩次取反荧呐,它不會變化

- 如果對非布爾值進(jìn)行元素,則會將其轉(zhuǎn)換為布爾值,然后再取反

所以我們可以利用該特點(diǎn)倍阐,來將一個其他的數(shù)據(jù)類型轉(zhuǎn)換為布爾值

可以為一個任意數(shù)據(jù)類型取兩次反概疆,來將其轉(zhuǎn)換為布爾值,原理和Boolean()函數(shù)一樣

&& 與

- &&可以對符號兩側(cè)的值進(jìn)行與運(yùn)算并返回結(jié)果

- 運(yùn)算規(guī)則

- 兩個值中只要有一個值為false就返回false峰搪,

只有兩個值都為true時岔冀,才會返回true

- JS中的“與”屬于短路的與,

如果第一個值為false概耻,則不會看第二個值

|| 或

- ||可以對符號兩側(cè)的值進(jìn)行或運(yùn)算并返回結(jié)果

- 運(yùn)算規(guī)則:

- 兩個值中只要有一個true使套,就返回true

如果兩個值都為false,才返回false

- JS中的“或”屬于短路的或

如果第一個值為true鞠柄,則不會檢查第二個值

*/

var a = true;

//對a進(jìn)行非運(yùn)算

a = !a;

//console.log("a = " + a);

var b = 10;

b = !!b;

//console.log("b = " + b);

//console.log(typeof b);

//如果兩個值都是true則返回true

var result = true && true;

//只要有一個false侦高,就返回false

result = true && false;

result = false && true;

result = false && false;

//console.log("result = "+result);

//第一個值為true,會檢查第二個值

//true && alert("看我出不出來Q岫拧奉呛!");

//第一個值為false,不會檢查第二個值

//false && alert("看我出不出來:痪 瞧壮!");

//兩個都是false啊胶,則返回false

result = false || false;

//只有有一個true,就返回true

result = true || false;

result = false || true ;

result = true || true ;

//console.log("result = "+result);

//第一個值為false骑篙,則會檢查第二個值

//false || alert("123");

//第一個值為true熏迹,則不再檢查第二個值

true || alert("123");

2.與或運(yùn)算

/*

&& || 非布爾值的情況

- 對于非布爾值進(jìn)行與或運(yùn)算時,會先將其轉(zhuǎn)換為布爾值汉柒,然后再運(yùn)算,并且返回原值

- 與運(yùn)算:

- 如果第一個值為true,則必然返回第二個值

- 如果第一個值為false赠堵,則直接返回第一個值

- 或運(yùn)算

- 如果第一個值為true,則直接返回第一個值

- 如果第一個值為false法褥,則返回第二個值

*/

//true && true

//與運(yùn)算:如果兩個值都為true茫叭,則返回后邊的

var result = 2 && 1;

//與運(yùn)算:如果兩個值中有false,則返回靠前的false

//false && true

result = 0 && 2;

result = 2 && 0;

//false && false

result = NaN && 0;

result = 0 && NaN;

//true || true

//如果第一個值為true半等,則直接返回第一個值

result = 2 || 1;

result = 2 || NaN;

result = 2 || 0;

//如果第一個值為false揍愁,則直接返回第二個值

result = NaN || 1;

result = NaN || 0;

result = "" || "hello";

result = -1 || "你好";

console.log("result = "+result);

3.賦值運(yùn)算符

=

可以將符號右側(cè)的值賦值給符號左側(cè)的變量

+=

a += 5 等價于 a = a + 5

-=

a -= 5 等價于 a = a - 5

*=

a *= 5 等價于 a = a5

/=

a /= 5 等價于 a = a / 5

%=

a %= 5 等價于 a = a % 5

*/

var a = 10;

//a = a + 5;

//a += 5;

//a -= 5;

//a *= 5;

// a = a%3;

a %= 3;

4.關(guān)系運(yùn)算符

通過關(guān)系運(yùn)算符可以比較兩個值之間的大小關(guān)系,

如果關(guān)系成立它會返回true杀饵,如果關(guān)系不成立則返回false

> 大于號

- 判斷符號左側(cè)的值是否大于右側(cè)的值

- 如果關(guān)系成立莽囤,返回true,如果關(guān)系不成立則返回false

>= 大于等于

- 判斷符號左側(cè)的值是否大于或等于右側(cè)的值

< 小于號

<= 小于等于

非數(shù)值的情況

- 對于非數(shù)值進(jìn)行比較時切距,會將其轉(zhuǎn)換為數(shù)字然后再比較

- 如果符號兩側(cè)的值都是字符串時朽缎,不會將其轉(zhuǎn)換為數(shù)字進(jìn)行比較,而會分別比較字符串中字符的Unicode編碼

*/

var result = 5 > 10;//false

result = 5 > 4; //true

result = 5 > 5; //false

result = 5 >= 5; //true

result = 5 >= 4; //true

result = 5 < 4; //false

result = 4 <= 4; //true

//console.log("result = "+result);

//console.log(1 > true); //false

//console.log(1 >= true); //true

//console.log(1 > "0"); //true

//console.log(10 > null); //true

//任何值和NaN做任何比較都是false

//console.log(10 > "hello"); //false

//console.log(10 >= "hello"); //false

//console.log(10 < "hello"); //false

//console.log(10 <= "hello"); //false

//console.log(true > false); //true

//console.log("1" < "5"); //true

//console.log("11" < "5"); //true

//比較兩個字符串時,比較的是字符串的字符編碼

//console.log("a" < "b");//true

//比較字符編碼時是一位一位進(jìn)行比較

//如果兩位一樣话肖,則比較下一位北秽,所以借用它來對英文進(jìn)行排序

// console.log("abc" < "b");//true

// console.log("bbc" < "b");//false

//console.log("abc" < "bcd");//true

//比較中文時沒有意義

//console.log("你" > "我"); //false

// console.log("月" > "我"); //true

//如果比較的兩個字符串型的數(shù)字,可能會得到不可預(yù)期的結(jié)果

//注意:在比較兩個字符串型的數(shù)字時最筒,一定一定一定要轉(zhuǎn)型

console.log("11123123123123123123" < +"5"); //false

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末贺氓,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子床蜘,更是在濱河造成了極大的恐慌辙培,老刑警劉巖,帶你破解...
    沈念sama閱讀 211,042評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件悄泥,死亡現(xiàn)場離奇詭異虏冻,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)弹囚,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 89,996評論 2 384
  • 文/潘曉璐 我一進(jìn)店門厨相,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人鸥鹉,你說我怎么就攤上這事蛮穿。” “怎么了毁渗?”我有些...
    開封第一講書人閱讀 156,674評論 0 345
  • 文/不壞的土叔 我叫張陵践磅,是天一觀的道長。 經(jīng)常有香客問我灸异,道長府适,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,340評論 1 283
  • 正文 為了忘掉前任肺樟,我火速辦了婚禮檐春,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘么伯。我一直安慰自己疟暖,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,404評論 5 384
  • 文/花漫 我一把揭開白布田柔。 她就那樣靜靜地躺著俐巴,像睡著了一般。 火紅的嫁衣襯著肌膚如雪硬爆。 梳的紋絲不亂的頭發(fā)上欣舵,一...
    開封第一講書人閱讀 49,749評論 1 289
  • 那天,我揣著相機(jī)與錄音摆屯,去河邊找鬼邻遏。 笑死糠亩,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的准验。 我是一名探鬼主播赎线,決...
    沈念sama閱讀 38,902評論 3 405
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼糊饱!你這毒婦竟也來了垂寥?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,662評論 0 266
  • 序言:老撾萬榮一對情侶失蹤另锋,失蹤者是張志新(化名)和其女友劉穎滞项,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體夭坪,經(jīng)...
    沈念sama閱讀 44,110評論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡文判,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,451評論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了室梅。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片戏仓。...
    茶點(diǎn)故事閱讀 38,577評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖亡鼠,靈堂內(nèi)的尸體忽然破棺而出赏殃,到底是詐尸還是另有隱情,我是刑警寧澤间涵,帶...
    沈念sama閱讀 34,258評論 4 328
  • 正文 年R本政府宣布仁热,位于F島的核電站,受9級特大地震影響勾哩,放射性物質(zhì)發(fā)生泄漏抗蠢。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,848評論 3 312
  • 文/蒙蒙 一思劳、第九天 我趴在偏房一處隱蔽的房頂上張望物蝙。 院中可真熱鬧,春花似錦敢艰、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,726評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至森瘪,卻和暖如春牡属,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背扼睬。 一陣腳步聲響...
    開封第一講書人閱讀 31,952評論 1 264
  • 我被黑心中介騙來泰國打工逮栅, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留悴势,地道東北人。 一個月前我還...
    沈念sama閱讀 46,271評論 2 360
  • 正文 我出身青樓措伐,卻偏偏與公主長得像特纤,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子侥加,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,452評論 2 348

推薦閱讀更多精彩內(nèi)容