Rumah > hujung hadapan web > tutorial js > Bagaimanakah saya boleh mengakses 'ini' yang betul dalam panggilan balik?

Bagaimanakah saya boleh mengakses 'ini' yang betul dalam panggilan balik?

WBOY
Lepaskan: 2023-08-24 09:53:09
ke hadapan
1027 orang telah melayarinya

Bagaimanakah saya boleh mengakses ini yang betul dalam panggilan balik?

Dalam tutorial ini kita akan melihat cara untuk mengakses "ini" yang betul dalam panggilan balik.

kata kunci "ini"

Setiap fungsi mengandungi kata kunci yang dipanggil ini, juga dikenali sebagai "konteks", yang nilainya ditentukan oleh cara fungsi dipanggil, bukan oleh bagaimana, bila, atau di mana fungsi itu ditakrifkan. Tidak seperti pembolehubah lain, ia tidak dipengaruhi oleh skop leksikal. Berbanding dengan bahasa lain, JavaScript berkelakuan sedikit berbeza apabila menggunakan kata kunci "ini" sesuatu fungsi. Terdapat beberapa perubahan lanjut antara mod ketat dan tidak ketat.

Cara fungsi yang paling biasa dipanggil menentukan nilai "ini" (runtime binding). Ia mungkin berubah setiap kali fungsi dipanggil, dan tidak boleh diubah oleh tugasan pada masa pelaksanaan. Bilangan kali fungsi dipanggil, kaedah bind() boleh menetapkan nilai ini kerana fungsi anak panah tidak menyediakan pengikatan "ini" mereka sendiri (ia mengekalkan nilai "ini" konteks leksikal yang disertakan).

Apakah panggilan balik?

Fungsi yang menerima parameter daripada fungsi lain dipanggil panggil balik dan biasanya digunakan kemudian dalam fungsi luaran. Fungsi tertib tinggi ialah istilah yang digunakan untuk menerangkan fungsi luaran yang menerima panggilan balik.

Panggil balik mempunyai set kaedah dan sifat tersendiri kerana fungsi ialah objek dalam JavaScript. Atribut "ini" yang diberikan kepada panggilan balik apabila dilaksanakan dalam fungsi tertib tinggi bergantung sepenuhnya pada cara panggilan balik dibuat, bukan di mana, bagaimana, atau bila ia ditakrifkan.

Dengan memeriksa fungsi tertib tinggi yang memanggil panggilan balik, kami boleh menentukan nilai "ini" dalam panggilan balik. Takrifan sebenar fungsi melampirkan mungkin termasuk sifat skop setempat, yang merupakan punca utama masalah ini dalam panggilan balik. Walau bagaimanapun, memandangkan konteks panggilan balik berubah secara dinamik bergantung pada cara ia dipanggil, apabila harta itu diakses melalui pengikatan "ini" dalam panggilan balik, ia tidak wujud.

Sekarang kita akan belajar cara mengakses "ini" yang betul dalam panggilan balik.

Gunakan mod "diri"

Mencipta pembolehubah bernama diri dan memberikannya nilai ini dalam skop fungsi yang diisytiharkan ialah corak biasa. Kita boleh mencapai tingkah laku yang diingini dengan mencipta pembolehubah baharu yang dipanggil diri (atau mana-mana nama pembolehubah sah lain akan dilakukan) dan memberikannya nilai "ini".

Contoh

<html>
<body>
   <h2> 'this' Inside a Callback using the <i> 'self' pattern </i> </h2>
   <button onclick="myFunction()"> Click here </button>
   <div id="root" style="
      background-color: rgb(240, 248, 255);
      border: 1px solid gray;
      margin: 5px 0px;
      padding: 10px;
   ">
      Welcome to Tutorialspoint!
   </div>
   <script>
      const root = document.getElementById('root')
      function myFunction() {
         this.variable = 'I am this variable'
         const variable = 'I am a const variable'
         const self = this
         setTimeout(() => {
            root.innerHTML = this.variable + '<br/>'
            root.innerHTML += variable
         }, 1000)
      }
   </script>
</body>
</html>
Salin selepas log masuk

Gunakan fungsi anak panah

ECMAScript 6 melihat kemunculan pertama fungsi anak panah JavaScript. Mereka tidak mempunyai ikatan sendiri dan merupakan alternatif yang lebih bersih kepada ungkapan fungsi tradisional. Ini memastikan bahawa jika ini dirujuk dalam fungsi anak panah, ia dicari dalam skop sebagai pembolehubah biasa.

Contoh

<html>
<body>
   <h2> 'this' Inside a Callback using the <i> arrow function </i> </h2>
   <button onclick="myFunction('ABC')"> Click here </button>
   <div id="root" style="
      background-color: rgb(240, 248, 255);
      border: 1px solid gray;
      margin: 5px 0px;
      padding: 10px;
   ">
      Welcome to Tutorialspoint!
   </div>
   <script>
      const root = document.getElementById('root')
      function myFunction(name) {
         this.name = name
         let obj = {
            run: function(callback) {
               setTimeout(callback, 1000)
            },
         }
         obj.run(() => {
            root.innerHTML = this.name
         })
      }
   </script>
</body>
</html>
Salin selepas log masuk

Gunakan pembolehubah lain untuk menyimpan objek "ini"

Objek dipautkan kepadanya, yang biasanya merupakan objek yang sebenarnya ingin kita akses apabila kita cuba mengaksesnya dalam panggilan balik. Mencipta pembolehubah dan menyimpan nilainya sebelum skop panggil balik adalah satu cara untuk mencapai ini (walaupun sesetengah pengaturcara enggan melakukan ini kerana ia kelihatan mengelirukan).

Sesetengah orang menyebutnya sebagai "itu" atau "diri", tetapi asalkan istilahnya jelas, tidak mengapa. Penyelesaian ini berfungsi dengan baik kerana pembolehubah memenuhi keperluan skop leksikal dan oleh itu boleh digunakan dalam panggilan balik. Anda masih mempunyai akses kepada pengikatan ini dinamik panggilan balik, yang merupakan satu lagi faedah pendekatan ini.

Contoh

<html>
<body>
   <h2>
      'this' Inside a Callback using the
      <i> another variable to store the 'this' object </i>
   </h2>
   <button onclick="myFunction('XYZ')"> Click here </button>
   <div id="root" style="
      background-color: rgb(240, 248, 255);
      border: 1px solid gray;
      margin: 5px 0px;
      padding: 10px;
   ">
      Welcome to Tutorialspoint!
   </div>
   <script>
      const root = document.getElementById('root')
      function myFunction(name) {
         this.name = name
         let that = this
         let obj = {
            run: function(callback) {
               setTimeout(callback, 1000)
            },
         }
         obj.run(function() {
            root.innerHTML = this.name
         })
      }
   </script>
</body>
</html>
Salin selepas log masuk

Gunakan pengikatan eksplisit ini pada objek

Apabila kami menentukan panggilan balik, kami boleh mengisytiharkan perkara yang kami mahu. Kita boleh menetapkan nilai "ini" menggunakan kaedah bind() dan memastikan ia kekal seperti itu sepanjang pelaksanaan fungsi, tidak kira bagaimana atau di mana ia dipanggil atau diluluskan.

Kaedah

bind() tersedia dalam setiap fungsi dan mencipta fungsi baharu dengan sifat "ini" yang disambungkan kepada objek yang diberikan. Satu-satunya perbezaan antara fungsi yang dikembalikan dan fungsi asal ialah anda mempunyai kawalan sepenuhnya ke atas apa yang ditunjukkan oleh atribut "ini".

Contoh

<html>
<body>
   <h2>
      'this' Inside a Callback using
      <i> explicitly binding this to an object </i>
   </h2>
   <button onclick="myFunction('Tutorialspoint')"> Click here </button>
   <div id="root" style="
      background-color: rgb(240, 248, 255);
      border: 1px solid gray;
      margin: 5px 0px;
      padding: 10px;
   ">
      Welcome to Tutorialspoint!
   </div>
   <script>
      const root = document.getElementById('root')
      function myFunction(name) {
         this.name = name
         let callbackFunction = function() {
            root.innerHTML = this.name
         }.bind(this)
         let obj = {
            run: function(callbackFunction) {
               setTimeout(callbackFunction, 1000)
            },
         }
         obj.run(callbackFunction)
      }
   </script>
</body>
</html>
Salin selepas log masuk

Atas ialah kandungan terperinci Bagaimanakah saya boleh mengakses 'ini' yang betul dalam panggilan balik?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:tutorialspoint.com
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan