將jQuery $(this) 與ES6 箭頭函數一起使用:詞法This 綁定
當將jQuery 的$this(this() 與ES6 箭頭函數一起使用時,開發人員可能會遇到這樣的問題:使用self = this 將$(this)轉換為 ES5 風格的閉包。此行為是由於箭頭函數的詞法綁定性質所造成的。
問題:
以下程式碼示範了這個問題:
何時使用箭頭函數取代:
$(this) 轉換為ES5風格的閉包,導致意外行為。
解:
這個問題是ES6箭頭函數的固有特徵,無法使用Traceur繞過。要解決此問題,必須避免使用它來存取單擊的元素。相反,可以使用event.currentTarget 屬性:
jQuery 專門提供了event.currentTarget 來應對由於外部因素導致this 綁定可能不明確的情況,例如回調函數被綁定到另一個上下文通過.bind().
以上是為什麼 `$(this)` 在 jQuery 和 ES6 箭頭函數中表現不佳?的詳細內容。更多資訊請關注PHP中文網其他相關文章!