」工欲善其事,必先利其器。「—孔子《論語.錄靈公》
首頁 > 程式設計 > JavaScript 中邏輯與 (&&) 和或 (||) 的靈活運用

JavaScript 中邏輯與 (&&) 和或 (||) 的靈活運用

發佈於2024-11-04
瀏覽:563

Flexible Uses of the Logical AND (&&) and OR (||) in JavaScript

介绍

布尔值是绝对值,true 或 false。这是非常明确的。 JavaScript 中的其他数据类型也具有这些固有值 true 和 false,但并不那么明显,因为它们看起来像 32、null、0 和“Hello”,而不是 true 和 false。知道所有值都具有这些固有值意味着我们可以对通常用于布尔值的所有数据类型执行操作。这为我们在编码时提供了更多的创造力和灵活性。

理解真值和假值

当使用 if 等控制流关键字和 AND (&&) 和 OR (||) 等逻辑运算符时,我们使用布尔值来实现某些结果。这些布尔值可以显式地与 true 或 false 一起使用,但我们经常使用比较运算符(例如 ===、)生成它们。

如果我们不使用具有控制流或逻辑运算符的布尔值会发生什么?好吧,你很幸运!所有价值观本质上都是真或假,以帮助实现这一点。我们可以将所有值分为两类:truthyfalsy.

当试图确定一个值是真值还是假值时,最好记住 falsy 值,因为它们的数量有限:

  • false(布尔值)
  • 无效的
  • 不明确的
  • NaN(不是数字)
  • 0(数值)
  • ""(空字符串值)

其他一切都是真实。如果您不确定某些内容是真还是假,或者遇到似乎不明确的独特情况,您始终可以创建一个 if 语句来查看以下代码块中的代码是否运行。

if (23) { console.log(“truthy”); } // Prints “truthy”
else { console.log(“falsy”); }

if (null) { console.log(“truthy”); } 
else { console.log(“falsy”); } // Prints “falsy”

逻辑与 (&&)

当将布尔值与逻辑 AND (&&) 一起使用时,两个值都必须为 true 才能使逻辑运算符返回 true。否则,如果至少有一个值为 false,则返回 false。

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

了解逻辑 AND (&&) 运算符的机制可以帮助您处理真值和假值。如果左边的值为 false,则返回;否则,返回右侧的值。

console.log(0 && 1); // 0
console.log("a" && ""); // "" (an empty string)
console.log([] && [1, 2, 3]); // [1, 2, 3]

逻辑 AND (&&) 运算符想要返回一个假值,并且只有在两者都为真时才返回右侧的真值。你可以这样想两个参数:

(左侧)仅当我是虚假值时才使用我。 &&(右侧)否则,请使用我。

逻辑或 (||)

当将布尔值与逻辑 OR (||) 结合使用时,两个值都必须为 false 才能使逻辑运算符返回 false。否则,如果至少有一个值为 true,则返回 true。

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

逻辑 OR (||) 运算符的工作原理如下:如果左边的值为 true,则返回它;否则返回该值。否则,返回右侧的值。

console.log(1 || 0); // 1
console.log("" || "a"); // "a"
console.log(undefined || null); // null
console.log([] || [1, 2, 3]); // []

逻辑 OR (||) 运算符想要返回真值,并且仅在两者均为假值时才返回右侧的假值。你可以这样想两个参数:

(左侧)仅当我具有真实值时才使用我。 || (右侧)不然就用我吧。

AND (&&) 和 OR (||) 的创造性运用

期望输入时使用默认值

假设您正在创建一个代表一个人的对象,该对象具有描述该人的属性以及使用该对象中的其他属性向其他人打招呼的函数。

function Person(name) {
    // If name is undefined, this.name will 
    // default to 'a person with no name'
    this.name = name || 'a person with no name';
    this.greet = function() {
        console.log('Hello, I am '   this.name   '.');
    };
}

// Create Person variables
var tyler = new Person('Tyler');
var mystery = new Person(); 
// Without an input, this.name defaults to the 
// second option since name is undefined.

// Call greet() from each Person object
tyler.greet(); // "Hello, I am Tyler."
mystery.greet(); // "Hello, I am a person with no name."

在上面的示例中,我们期望输入 name 参数,因此仅当 name 未定义(函数调用时没有参数)时才使用 OR (||) 运算中的第二个值。

需要多个输入

如果您正在创建对象并希望在创建对象之前确保拥有一定数量的输入,则可以将每个必需参数之间的逻辑 AND (&&) 运算符链接在一起。

function Person(firstName, lastName, age) {
  if (firstName && lastName && age) {
    this.firstName = firstName;
    this.lastName = lastName;
    this.fullName = `${this.firstName} ${this.lastName}`;
    this.age = age;
    this.greet = function() {
      console.log(`Hello, my name is ${this.fullName} and I'm ${this.age} years old.`);
    };
  } 

  // If any argument is missing, the object will only have this property.
  else {
    this.greet = function() {
      console.log(`Hello, I am not a fully formed Person.`)
    };
  }
}

var tyler = new Person('Tyler', 'Meyer', 32);
var brad = new Person('Brad', '', 38);

tyler.greet(); // "Hello, my name is Tyler Meyer and I'm 32 years old."
brad.greet(); // "Hello, I am not a fully formed Person."

if 语句在创建完整的 Person 对象之前检查每个参数的参数。如果即使有一个参数是假值,它也会使用 else 语句创建一个对象。因此,我们可以防止不完整的对象或为不完整的条目创建默认对象。

结论

如果在提供值之前需要默认值,则逻辑 OR (||) 运算符可能非常有用。如果您需要在继续之前需要多个值,逻辑 AND (&&) 运算符会非常有帮助。这些只是两个示例,当您继续探索这些运算符时,您会发现除了通常检查布尔值的真或假之外,还有更多使用这些运算符的方法。在考虑使用逻辑 AND (&&) 和 OR (||) 时,请记住这两点:

  • OR (||) :如果是 truthy.
  • ,则仅使用左侧的值
  • AND (&&) :如果左侧的值是 falsy.
  • ,则仅使用左侧的值

如果您有任何疑问,请在评论中留言。我很乐意进一步讨论这个话题。

编码愉快!

版本聲明 本文轉載於:https://dev.to/tymey/flexible-uses-of-the-logical-and-and-or-in-javascript-1c6o?1如有侵犯,請聯繫[email protected]刪除
最新教學 更多>
  • 如何干淨地刪除匿名JavaScript事件處理程序?
    如何干淨地刪除匿名JavaScript事件處理程序?
    刪除匿名事件偵聽器將匿名事件偵聽器添加到元素中會提供靈活性和簡單性,但是當要刪除它們時,可以構成挑戰,而無需替換元素本身就可以替換一個問題。 element? element.addeventlistener(event,function(){/在這里工作/},false); 要解決此問題,請考...
    程式設計 發佈於2025-06-10
  • 如何修復\“常規錯誤:2006 MySQL Server在插入數據時已經消失\”?
    如何修復\“常規錯誤:2006 MySQL Server在插入數據時已經消失\”?
    How to Resolve "General error: 2006 MySQL server has gone away" While Inserting RecordsIntroduction:Inserting data into a MySQL database can...
    程式設計 發佈於2025-06-10
  • 在JavaScript中如何並發運行異步操作並正確處理錯誤?
    在JavaScript中如何並發運行異步操作並正確處理錯誤?
    同意操作execution 在執行asynchronous操作時,相關的代碼段落會遇到一個問題,當執行asynchronous操作:此實現在啟動下一個操作之前依次等待每個操作的完成。要啟用並發執行,需要進行修改的方法。 第一個解決方案試圖通過獲得每個操作的承諾來解決此問題,然後單獨等待它們: c...
    程式設計 發佈於2025-06-10
  • PHP未來:適應與創新
    PHP未來:適應與創新
    PHP的未來將通過適應新技術趨勢和引入創新特性來實現:1)適應云計算、容器化和微服務架構,支持Docker和Kubernetes;2)引入JIT編譯器和枚舉類型,提升性能和數據處理效率;3)持續優化性能和推廣最佳實踐。 引言在編程世界中,PHP一直是網頁開發的中流砥柱。作為一個從1994年就開始發展...
    程式設計 發佈於2025-06-10
  • 反射動態實現Go接口用於RPC方法探索
    反射動態實現Go接口用於RPC方法探索
    在GO 使用反射來實現定義RPC式方法的界面。例如,考慮一個接口,例如:鍵入myService接口{ 登錄(用戶名,密碼字符串)(sessionId int,錯誤錯誤) helloworld(sessionid int)(hi String,錯誤錯誤) } 替代方案而不是依靠反射...
    程式設計 發佈於2025-06-10
  • 如何從Python中的字符串中刪除表情符號:固定常見錯誤的初學者指南?
    如何從Python中的字符串中刪除表情符號:固定常見錯誤的初學者指南?
    從python import codecs import codecs import codecs 導入 text = codecs.decode('這狗\ u0001f602'.encode('utf-8'),'utf-8') 印刷(文字)#帶有...
    程式設計 發佈於2025-06-10
  • Python中嵌套函數與閉包的區別是什麼
    Python中嵌套函數與閉包的區別是什麼
    嵌套函數與python 在python中的嵌套函數不被考慮閉合,因為它們不符合以下要求:不訪問局部範圍scliables to incling scliables在封裝範圍外執行範圍的局部範圍。 make_printer(msg): DEF打印機(): 打印(味精) ...
    程式設計 發佈於2025-06-10
  • Android如何向PHP服務器發送POST數據?
    Android如何向PHP服務器發送POST數據?
    在android apache httpclient(已棄用) httpclient httpclient = new defaulthttpclient(); httppost httppost = new httppost(“ http://www.yoursite.com/script.p...
    程式設計 發佈於2025-06-10
  • 為什麼PYTZ最初顯示出意外的時區偏移?
    為什麼PYTZ最初顯示出意外的時區偏移?
    與pytz 最初從pytz獲得特定的偏移。例如,亞洲/hong_kong最初顯示一個七個小時37分鐘的偏移: 差異源利用本地化將時區分配給日期,使用了適當的時區名稱和偏移量。但是,直接使用DateTime構造器分配時區不允許進行正確的調整。 example pytz.timezone(&#...
    程式設計 發佈於2025-06-10
  • Python讀取CSV文件UnicodeDecodeError終極解決方法
    Python讀取CSV文件UnicodeDecodeError終極解決方法
    在試圖使用已內置的CSV模塊讀取Python中時,CSV文件中的Unicode Decode Decode Decode Decode decode Error讀取,您可能會遇到錯誤的錯誤:無法解碼字節 在位置2-3中:截斷\ uxxxxxxxx逃脫當CSV文件包含特殊字符或Unicode的路徑逃...
    程式設計 發佈於2025-06-10
  • CSS強類型語言解析
    CSS強類型語言解析
    您可以通过其强度或弱输入的方式对编程语言进行分类的方式之一。在这里,“键入”意味着是否在编译时已知变量。一个例子是一个场景,将整数(1)添加到包含整数(“ 1”)的字符串: result = 1 "1";包含整数的字符串可能是由带有许多运动部件的复杂逻辑套件无意间生成的。它也可以是故意从单个真理...
    程式設計 發佈於2025-06-10
  • HTML格式標籤
    HTML格式標籤
    HTML 格式化元素 **HTML Formatting is a process of formatting text for better look and feel. HTML provides us ability to format text without us...
    程式設計 發佈於2025-06-10
  • JavaScript計算兩個日期之間天數的方法
    JavaScript計算兩個日期之間天數的方法
    How to Calculate the Difference Between Dates in JavascriptAs you attempt to determine the difference between two dates in Javascript, consider this s...
    程式設計 發佈於2025-06-10
  • 在Java中使用for-to-loop和迭代器進行收集遍歷之間是否存在性能差異?
    在Java中使用for-to-loop和迭代器進行收集遍歷之間是否存在性能差異?
    For Each Loop vs. Iterator: Efficiency in Collection TraversalIntroductionWhen traversing a collection in Java, the choice arises between using a for-...
    程式設計 發佈於2025-06-10
  • Async Void vs. Async Task在ASP.NET中:為什麼Async Void方法有時會拋出異常?
    Async Void vs. Async Task在ASP.NET中:為什麼Async Void方法有時會拋出異常?
    在ASP.NET async void void async void void void void void的設計無需返回asynchroncon而無需返回任務對象。他們在執行過程中增加未償還操作的計數,並在完成後減少。在某些情況下,這種行為可能是有益的,例如未期望或明確預期操作結果的火災和...
    程式設計 發佈於2025-06-10

免責聲明: 提供的所有資源部分來自互聯網,如果有侵犯您的版權或其他權益,請說明詳細緣由並提供版權或權益證明然後發到郵箱:[email protected] 我們會在第一時間內為您處理。

Copyright© 2022 湘ICP备2022001581号-3