當前位置:
首頁 >
前端技术
> javascript
>内容正文
javascript
javascript中基本包装、算数运算符、递增递减运算符、赋值运算符、比较运算符、逻辑运算符、运算符优先级
生活随笔
收集整理的這篇文章主要介紹了
javascript中基本包装、算数运算符、递增递减运算符、赋值运算符、比较运算符、逻辑运算符、运算符优先级
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
基本包裝類型:
指基本類型的數據變量通過調用屬性或者方法包裝成了復雜類型,這個變量也稱為基本包裝類型對象
<script>var str = 'hello';str = str.replace('ll', 'ee');console.log(str); //heeeo//通過基本包裝,無論Boolean對象中傳入true還是false,在邏輯與中其結果都是&&后面的值:var flag = new Boolean(false)var result = flag && true;console.log(result); //truevar flag1 = new Boolean(true)var result1 = flag1 && true;console.log(result1); //truevar flag2 = new Boolean(true)var result2 = flag2 && false;console.log(result2); //false</script>操作符
指一些符號,用來做運算的,具體如下:
算數運算符:
+、- 、 * 、/ 、%
<script>//算數運算:console.log(111 + 222); //333console.log(111 - 222); //-111console.log(111 * 222); //24642console.log(111 / 222); //0.5console.log(5 % 3); //2var num = 10;var sum = (5 + num)*2;console.log(sum);//30</script>遞增遞減運算符(一元運算符):
++ 、–(前置++(–)和后置++(–)的區別:前置++或–是先參與運算,之后在自身+1或-1;后置++或–是先自身+1或-1,之后在參與運算)、delete刪除一個對象的屬性或者一個數組中某一個鍵值、void 運算符(不常用)、in關系運算符(判斷某個變量是否在某數據中)、
<script>//也可以叫一元運算符:var num = 10;console.log(num++); //10console.log(num); //11console.log(++num); //12console.log(num); //12var num2 = 10;console.log(++num2); //11console.log(num2); //11console.log(num2++); //11console.log(num2); //12//后置++:先參與運算,運算完后自身在+1(后置--同理)//前置++:先自身+1,然后再參與運算(前置--同理)var num = 10;var sum = ++num + 10;console.log(sum); //21console.log(num); //11var num = 10;var sum = num++ + 10;console.log(sum); //20console.log(num); //11var num = 10;var sum = num++ + ++num; //特別注意,當num自己每運算一次,自己的值就會改變,因此:10 + 12 = 22console.log(sum); //22console.log(num); //12var num = 10;var sum = ++num + num++; //11 + 11 = 22console.log(sum); //22console.log(num); //12var num = 10;var sum = ++num + ++num; //11 + 12 = 23console.log(sum); //23console.log(num); //12var num = 10;var sum = num++ + num++; //10 + 11 = 21console.log(sum); //21console.log(num); //12//delete刪除數組元素或對象的屬性:var x = 3,arr = [1, 2],obj = {naem: 'jack'};delete x;console.log(x); //3,不能刪除除數組和對象的其他數據類型的數據delete arr[0];console.log(arr[0]); //undefinedconsole.log(arr[1]); //2delete obj[name];console.log(obj.name); //undefined// 邏輯中斷或短路引起代碼不執行情況:var num1 = 10;var result1 = false && ++num1;var result2 = true || num1++;console.log(num1); //10//void(表達式),第一個案例不會被跳轉,第二個案例會被跳轉:<a href="javascript:void(0)">點擊</a><a href="javascript:void(document.form.submit())">點擊</a>//判斷屬性是否在對象中:var obj = {name: 'jack'};if ('name' in obj) {console.log('name屬性存在obj中'); //name屬性存在obj中,注意屬性是字符串};</script>賦值運算符:
+=、-=、*=、/=、%=、**=、<<=(左移位賦值,<<為左移位運算)
<script>var num1 = 10;num1 += 1;console.log(num1); //11var num2 = 10;num2 -= 2;console.log(num2); //8var num3 = 10;num3 *= 2;console.log(num3); //20var num4 = 10;num4 /= 2;console.log(num4); //5var num5 = 10;num5 %= 7;console.log(num5); //3var num = 2;num **= 3;console.log(num);//8var a = 2;var b = 3;a <<= b; //a = a << b;console.log(a); //16</script>比較運算符:
/>、<、>=、<=、== 、 ===、 != 、 !==
<script>console.log(10 > 5); //truwconsole.log(10 < 5); //falseconsole.log(10 >= 5); //truwconsole.log(10 <= 5); //falseconsole.log('5' == 5); //trueconsole.log('5' === 5); //falseconsole.log('5' != 5); //falseconsole.log('5' !== 5); //true</script>邏輯運算符:
&&–與,并且、||–或,或者、!–非,取反(邏輯中斷情況:當&&前面的表達式是非 時,后面的表達式不再執行,當||前面的表達式為真時,后面的表達式不再執行),擴展二進制邏輯運算符:&(按位與)、~(按位非)、|(按位或)、^(按位異或)
<script>//邏輯運算:console.log(false&&false);//falseconsole.log(true&&true);//trueconsole.log(false&&true);//falseconsole.log(true&&false);//falseconsole.log(false||false);//falseconsole.log(true||true);//trueconsole.log(false||true);//trueconsole.log(true||false);//trueconsole.log(111 && 222); //222console.log(111 || 222); //111console.log(111 != 222); //trueconsole.log(111 > 222 && true); //falseconsole.log(111 < 222 && false); //falseconsole.log(111 > 222 || true); //trueconsole.log(111 < 222 || false); //truevar num1 = 10;var num2 = 20;console.log(num1=num2&&5>6);//falseconsole.log(num2>10||5<0);//truevar num1 = 10;var sum = (num1+10)*5;console.log(sum);//100var result = (4 >= 6 || '人' != '狗' && !(12 * 2 == 144) && true);console.log(result);//truevar num = 10;var result2 = (5 == num / 2 &&(2 + 2*num).toString() === '22');console.log(result2);//true</script>運算符優先級:
提示:本文圖片等素材來源于網絡,若有侵權,請發郵件至郵箱:810665436@qq.com聯系筆者 刪除。
筆者:苦海
總結
以上是生活随笔為你收集整理的javascript中基本包装、算数运算符、递增递减运算符、赋值运算符、比较运算符、逻辑运算符、运算符优先级的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: python math库函数源码_11.
- 下一篇: idea下拉项目_推荐几款非常好用的ID