javascript算術運算子有:加法運算子“ ”,減法運算子“-”、乘法運算子“*”、除法運算子“/”、求餘運算子“%”、遞增運算符「 」、遞減運算子「--」、冪運算子「**」。
本教學操作環境:windows7系統、javascript1.8.5版、Dell G3電腦。
算術運算子用於對數字(文字或變數)執行算術運算。標準算術運算子是加法
,減法 -
,乘法 *
和除法 /
。和數學裡面的加減乘除很類似,我們一起來看看。
加法運算子
加法運算子
的作用是數值求和,這個應該很簡單。
範例:
下面是簡單的求兩數總和:
var a = 8; var b = a + 5; console.log(b); // 13
激發運算子除了計算兩數總和,我們可以透過
連接字串,得到的結果是一個新的字串。
範例:
使用
將定義好的三個變數連接:
str1 = "hello"; str2 = "xkd"; str3 = " "; console.log(str1 + str3 + str2); // 输出: hello xkd
除此之外,數字和一個字串也可以透過
加號連接,回傳結果同樣為一個字串。
範例:
看一下數字與數字相加,數字與字串相加有什麼不同:
num1 = 10; num2 = 15; str1 = "15" console.log(num1 + num2 ); // 输出: 25 console.log(num1 + str1 ); // 输出:1015
注意在某些編程語言(例如Python)中不同類型是不能相加的,例如數字加字串會報錯。而 JavaScript 中數字和字串相加,回傳一個字串。
減法運算子
減法運算子 -
可以用於兩個運算元相減,結果為它們的差值。
範例:
var c = 8; var d = c - 5; console.log(d); // 3
在減法運算中,如果運算元為字串,先試著把它轉換為數值,再進行運算。如果有一個操作數不是數字,則傳回 NaN。
範例:
console.log(2 - "1"); //返回1 console.log(2 - "a"); //返回NaN
使用值減去 0,可以快速把值轉換為數字。例如 HTTP 請求中查詢字串一般都是字串型數字,可以先把這些參數值減去 0 轉換為數值。這與呼叫 parseFloat() 方法的結果相同,但減法更有效率、更快速。減法運算子的隱性轉換如果失敗,則傳回 NaN,這與使用 parseFloat() 方法執行轉換時的回傳值是不同的。
例如,對於字串「100aaa」而言,parseFloat() 方法能夠解析出前面幾個數字,而對於減法運算子來說,則必須是完整的數字,才可以進行轉換。
console.log(parseFloat("100aaa")); //返回100 console.log("100aaa" - 0); //返回NaN
對布林值來說,parseFloat() 方法能夠把 true 轉換為 1,把 false 轉換為 0,而減法運算子視其為 NaN。
對於物件來說,parseFloat() 方法會嘗試呼叫物件的toString() 方法轉換,而減法運算子先嘗試呼叫物件的valueOf() 方法轉換,失敗之後再呼叫toString()進行轉換。
注意特殊運算元的減法運算。
var n = 5; //定义并初始化任意一个数值 console.log(NaN - n); //NaN与任意操作数相减,结果都是NaN console.log(Infinity - n); //Infinity与任意操作数相减,结果都是Infinity console.log(Infinity - Infinity); //Infinity与Infinity相减,结果是NaN console.log((-Infinity) - (-Infinity)); //负Infinity相减,结果是NaN console.log((-Infinity) - Infinity); //正负Infinity相减,结果是-Infinity
取反運算
注意特殊運算元的取反運算
console.log(- 5); //返回-5。正常数值取负数 console.log(- "5"); //返回-5。先转换字符串数字为数值类型 console.log(- "a"); //返回NaN。无法完全匹配运算,返回NaN console.log(- Infinity); //返回-Infinity console.log(- (- Infinity)); //返回Infinity console.log(- NaN); //返回NaN
#乘法運算子
乘法運算子*
的結果是運算元的乘積。
範例:
var e = (8 + 5) * 3; var f = 'xkd' * 3; console.log(e); // 输出:39 console.log(f); // 输出:NaN
如果我們使用字串與一個數字相乘,最終傳回一個NaN,即非法數。
除法運算子
除法運算子/
的結果是運算元的商,左運算元是被除數,右邊運算子是除數。
範例:
var g = (9 - 3) / 3; var h = 3.0 / 1.0; var i = 1 / 2; console.log(g); //输出:2 console.log(h); //输出:3 console.log(i); //输出:0.5
我們要注意的是,在JavaScript 中1 / 2
這個結果帶小數點的運算,結果會帶小數點,例如0.5
。而在 Java 等語言中,不需要數字是明確的浮點數,1 / 2
的回傳結果為0。
求餘運算子
百分號%
# 是求餘運算符,傳回第一個運算元對第二個運算元的模(餘數),例如x % y
,得到的結果是x
除以y
的整數餘數。餘數大家應該知道,我們在數學中也學過,就是指整數觸發中被除數未被除盡的部分。
範例:
例如下面這段程式碼:
var m = 9; var n = 2; var mn = m % n; console.log(mn); //输出: 1
輸出結果為1,這其實很好理解,9 % 2
就是求9 除以2 的餘數,就是1。
那麼如果是 12 % 5
呢,輸出結果會是什麼? 12除以5會餘2,所以結果結果為2。現在你應該知道 %
要怎麼使用了吧。
遞增運算子
遞增運算子
為其運算元增加1,並傳回一個數值。如果使用後置,如x
,將會在遞增前傳回數值。若前置,如 x
,遞增後將會傳回數值。
範例:
#假设我们定义了一个变量 i
,然后使用自增运算符对 i
进行递增运算,将递增后的 i
赋值给了变量 j
,最终j
的输出结果为 6:
var i = 5; i++; var j = i; console.log(j); // 6
那为什么结果会是6呢,i++
其实就是表示在 i
的基础上加一,相当于i + 1
。
然后我们看一下递增运算符前置和后置,到底有什么区别,例如下面这个代码:
var a = 9; console.log(a++); // 输出:9 console.log(a); // 输出:10 console.log(++a); // 输出:11
- 变量 a 的值为9,然后使用后置递增运算符
a++
,第一次输出会在递增之前就返回数值,即输出结果还是 9。 - 然后此时输出 a 的值,可以看到 a 的值已经为10了,因为已经执行了一次递增运算符,所以加 1。
- 接着第三次输出时,使用前置递增运算符,这会在递增之后才返回数值,即输出结果为11。
递减运算符
递减运算符 --
为其操作数减去1,并返回一个数值。递减运算符和递增运算符的使用方法差不多,一个是减、一个是加,正好相反。
如果后置使用递减运算符,则在递减之前返回数值。如果前置使用,则在递减之后返回数值。
示例:
var b = 7; console.log(b--); // 输出:7 console.log(b); // 输出:6 console.log(--b); // 输出:5
- 变量b的值为7,然后使用后置递减运算符
b--
,会在递减之钱返回数值,即7。 - 然后第二次输出变量b,此时已经成功执行
b--
,会在此基础上减1,所以输出6。 - 第三次输出
--b
,使用后置递减运算符,会在递减之后返回数值,所以会输出5。
幂运算符
幂运算符 **
返回第一个操作数做底数,第二个操作数做指数的乘方。例如5 ** 2
表示 5 的 2 次方,根据所学数学知道就能得出结果为25。
示例:
下面这个代码表示求 6 的 3 次方,相当于 6 * 6 * 6
,结果为216:
var x = 6; var y = x ** 3; console.log(y); // 216
上面的运算出的结果与 Math.pow(x, y)
是相同的,例如:
var x = 6; var y = Math.pow(x,3); console.log(y); // 216
pow()
方法可返回 x 的 y 次幂的值。
【推荐学习:javascript高级教程】
以上是javascript算術運算子有哪些的詳細內容。更多資訊請關注PHP中文網其他相關文章!

JavaScript是現代網站的核心,因為它增強了網頁的交互性和動態性。 1)它允許在不刷新頁面的情況下改變內容,2)通過DOMAPI操作網頁,3)支持複雜的交互效果如動畫和拖放,4)優化性能和最佳實踐提高用戶體驗。

C 和JavaScript通過WebAssembly實現互操作性。 1)C 代碼編譯成WebAssembly模塊,引入到JavaScript環境中,增強計算能力。 2)在遊戲開發中,C 處理物理引擎和圖形渲染,JavaScript負責遊戲邏輯和用戶界面。

JavaScript在網站、移動應用、桌面應用和服務器端編程中均有廣泛應用。 1)在網站開發中,JavaScript與HTML、CSS一起操作DOM,實現動態效果,並支持如jQuery、React等框架。 2)通過ReactNative和Ionic,JavaScript用於開發跨平台移動應用。 3)Electron框架使JavaScript能構建桌面應用。 4)Node.js讓JavaScript在服務器端運行,支持高並發請求。

Python更適合數據科學和自動化,JavaScript更適合前端和全棧開發。 1.Python在數據科學和機器學習中表現出色,使用NumPy、Pandas等庫進行數據處理和建模。 2.Python在自動化和腳本編寫方面簡潔高效。 3.JavaScript在前端開發中不可或缺,用於構建動態網頁和單頁面應用。 4.JavaScript通過Node.js在後端開發中發揮作用,支持全棧開發。

C和C 在JavaScript引擎中扮演了至关重要的角色,主要用于实现解释器和JIT编译器。1)C 用于解析JavaScript源码并生成抽象语法树。2)C 负责生成和执行字节码。3)C 实现JIT编译器,在运行时优化和编译热点代码,显著提高JavaScript的执行效率。

JavaScript在現實世界中的應用包括前端和後端開發。 1)通過構建TODO列表應用展示前端應用,涉及DOM操作和事件處理。 2)通過Node.js和Express構建RESTfulAPI展示後端應用。

JavaScript在Web開發中的主要用途包括客戶端交互、表單驗證和異步通信。 1)通過DOM操作實現動態內容更新和用戶交互;2)在用戶提交數據前進行客戶端驗證,提高用戶體驗;3)通過AJAX技術實現與服務器的無刷新通信。

理解JavaScript引擎內部工作原理對開發者重要,因為它能幫助編寫更高效的代碼並理解性能瓶頸和優化策略。 1)引擎的工作流程包括解析、編譯和執行三個階段;2)執行過程中,引擎會進行動態優化,如內聯緩存和隱藏類;3)最佳實踐包括避免全局變量、優化循環、使用const和let,以及避免過度使用閉包。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

SublimeText3 英文版
推薦:為Win版本,支援程式碼提示!

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

mPDF
mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),

禪工作室 13.0.1
強大的PHP整合開發環境