首頁  >  文章  >  web前端  >  為什麼嵌套 JavaScript 函數中的「this」指標指向全域物件?

為什麼嵌套 JavaScript 函數中的「this」指標指向全域物件?

Susan Sarandon
Susan Sarandon原創
2024-10-19 06:48:30534瀏覽

Why Does the

巢狀函數中的JavaScript「this」指標之謎

在JavaScript 程式碼片段中,您遇到了有關「this」的意外行為" 巢狀函數內的指標。儘管在物件方法中定義了巢狀函數,但巢狀函數內的「this」指標指向全域「window」物件。

「this」指標的行為由函數呼叫方法決定JavaScript。方法中,「this」指標引用到呼叫函數的對象,在本例中為someThing.

  1. 使用call() 進行函數呼叫:someFunction.call(someThing,call(someThing,call(someThing,call(someThing,) arg1, arg2, argN)
    • call() 函數明確地將「this」指標設定為所提供的對象,在本例中為someThing。
  2. 使用apply() 進行函數呼叫: someFunction.apply(someThing, [arg1, arg2, argN])
  3. 與call() 類似,apply() 函數將「this 」指標設定為所提供的對象,但它需要一個而是參數數組。
  4. 在您提供的範例中,呼叫巢狀函數時無需任何明確函數呼叫方法。
  5. 使用std_obj.displayMe() 而不是std_obj.displayMe;明確呼叫displayMe 方法。 { var that = this; ... }

      使用call() 或apply() 函數設定「this」指標: doSomeEffects.call(std_obj);
    透過使用這些方法中的任何一個,您可以控制巢狀函數中「this」指標的行為,並確保它引用所需的物件。

以上是為什麼嵌套 JavaScript 函數中的「this」指標指向全域物件?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn