JavaScript中的短路求值
短路求值基本上使用&&和||邏輯運算子。從左向右計算這些表示式。
對於&&運算子 − 使用&&(AND)邏輯運算子進行短路求值,表示如果第一個表示式的值為假,則整個表示式的值為假,並且不會計算其餘表示式。
對於||運算子 − 使用||(OR)邏輯運算子進行短路求值,表示如果第一個表示式的值為真,則整個表示式的值為真,並且不會計算其餘表示式。
以下是JavaScript中短路求值程式碼 −
示例
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8" /> <meta name="viewport" content="width=device-width, initial-scale=1.0" /> <title>Document</title> <style> body { font-family: "Segoe UI", Tahoma, Geneva, Verdana, sans-serif; } .result { font-size: 20px; font-weight: 500; color: blueviolet; } </style> </head> <body> <h1>Short-circuit evaluation</h1> <div class="result"></div> <br /> <button class="Btn">&& short circuit evaluation</button> <button class="Btn">|| short circuit evaluation</button> <h3>Click on the above button to see the the short circuit evaluation</h3> <script> let resEle = document.querySelector(".result"); let BtnEle = document.querySelectorAll(".Btn"); function retTrue() { resEle.innerHTML += "True <br>"; return true; } function retFalse() { resEle.innerHTML += "False <br>"; return false; } BtnEle[0].addEventListener("click", () => { resEle.innerHTML = "&& evaluation<br>"; retFalse() && retTrue(); }); BtnEle[1].addEventListener("click", () => { resEle.innerHTML = "|| evaluation <br>"; retTrue() || retFalse(); }); </script> </body> </html>
輸出
單擊“&&短路求值”按鈕 −
單擊‘||短路求值”按鈕 −
廣告