jQuery 是一個流行的 JavaScript 庫,它提供了快速、簡化的 DOM 操作和事件處理方式。然而,有些人可能在使用 jQuery 的相等判斷時遇到了一些困惑。
相等判斷即使用雙等號 (==) 或三等號 (===) 來比較兩個值是否相等。在 JavaScript 中,雙等號會對對比的兩個值進行類型轉換,然后再進行比較;三等號則會嚴格比較,類型不同則一定不相等。
if (1 == "1") { console.log("相等"); } else { console.log("不相等"); } // 輸出 "相等" if (1 === "1") { console.log("相等"); } else { console.log("不相等"); } // 輸出 "不相等"
在使用 jQuery 的選擇器時,如果我們想判斷元素的 class 是否為某個值,可能會這樣寫:
if ($("div").attr("class") == "my-class") { console.log("class 相等"); }
然而,這樣寫是不正確的。因為在 HTML 中,class 可以包含多個值,而 jQuery 的 attr() 方法只返回字符串中的第一個 class 值。因此,如果一個元素有多個 class 值,上述判斷語句會返回 false。
正確的判斷方式是使用 jQuery 的 hasClass() 方法:
if ($("div").hasClass("my-class")) { console.log("class 相等"); }
總之,我們應該盡量避免使用雙等號來判斷 jQuery 對象的屬性或方法是否相等,而是使用專門的方法進行判斷。