Rumah hujung hadapan web tutorial js Perbincangan ringkas tentang kaedah melaksanakan pengikatan dua hala dalam angular.js $watch $digest $apply_AngularJS

Perbincangan ringkas tentang kaedah melaksanakan pengikatan dua hala dalam angular.js $watch $digest $apply_AngularJS

May 16, 2016 pm 03:36 PM
angular apply watch

Ciri dalam Angular.js, pengikatan dua hala.

Apakah fungsi ajaib yang membolehkan perubahan dalam paparan dicerminkan secara langsung dalam data Perubahan dalam data dimaklumkan kepada paparan dalam masa nyata.

Ini adalah terima kasih kepada 3 kaedah skop penting berikut:

$watch
$digest
$apply

Apakah perbezaan mereka? Mari perkenalkan mereka:

$watch
Ini ialah pendengar yang mendengar data pada skop

Penerangan kaedah:

$scope.$watch('参数',function(newValue,oldValue){
 //逻辑处理
})
Salin selepas log masuk

Kami mencipta pendengar di atas.
'Parameter' ialah objek (atau atribut objek) di bawah objek $scope. Ambil perhatian bahawa ini dalam bentuk rentetan

Andaikan anda ingin memantau sifat $scope.name.

$scope.$watch('name',function(newValue,oldValue){
 //逻辑处理
})
Salin selepas log masuk
Seperti dalam kod di atas, 'nama' memerlukan petikan

Parameter diikuti dengan fungsi panggil balik Parameter fungsi panggil balik mengembalikan atribut yang dipantau, nilai baharu selepas perubahan dan nilai lama sebelum perubahan sebelumnya.

$digest

Dia bertanggungjawab untuk menyemak sama ada data dalam skop telah berubah Jika atribut tertentu berubah, ia akan segera memberitahu pendengar atribut ini (pendengar yang didaftarkan oleh $watch), mencetuskan pendengar dan melaksanakan fungsi panggil balik. .

$mohon

Kaedah ini hampir sama dengan $digest, $digest menyemak semua data dalam skop

$apply adalah bersamaan dengan menyemak semua data dalam rootScope, ia akan menyemak semua data daripada ibu bapa kepada anak

$apply() == $rootScope.$digest()

Kaedah $apply() mempunyai dua bentuk.

Yang pertama menerima fungsi sebagai parameter.

Ini mencetuskan fungsi $digest dan melaksanakan fungsi
dalam parameter sekali

Jenis kedua tidak menerima sebarang parameter.

Ini hanya mencetuskan kitaran $digest ibu bapa kepada anak

Dalam Angular.js, $digest tidak akan dipanggil secara langsung, tetapi $scope.$apply() digunakan sebaliknya

Saya tidak menetapkan monitor, kenapa paparan dan data boleh terikat dalam dua arah

Contohnya, kotak teks ng-model="name"

Pada masa ini, sebenarnya terdapat nama atribut di bawah objek $scope untuk sepadan dengan pengikatan dua hala dengan paparan di atas

Bagaimana untuk mencapainya?

Malah, apabila kita mentakrifkan ng-model="name" atau ng-bind="name" atau {{name}}

Pada masa ini, angular.js secara automatik akan menetapkan pendengar untuk atribut "nama" pada model $scope:

$scope.$watch('name', function(newValue, oldValue) {
  //监听 name 属性的变化
});
Salin selepas log masuk
Nampaknya angular.js membantu kami membuat pendengar secara automatik, jadi sifat ini dan data $scope.name akan terikat dua hala dalam masa nyata.

Sudah tentu, kadangkala anda akan mendapati bahawa data telah berubah Tetapi UI tidak dimuatkan semula Adakah pengikatan dua hala tidak sah?

Tidak


Cuma apabila model $scope melintasi gelung digest, data anda belum dikembalikan lagi,

Sebagai contoh, apabila memanggil kaedah secara tidak segerak, data dikembalikan oleh callbac

Sebagai contoh, anda menetapkan fungsi pencetus yang dijadualkan dalam setTimeout, dan kemudian mengubah suai data model

Ringkasnya, kitaran ringkasan model $scope telah terlepas, menyebabkan model tidak memberitahu UI untuk memuat semula mengikut data baharu.

Apakah yang perlu saya lakukan jika saya menghadapi masalah sedemikian?

Kami perlu memanggil ringkasan secara manual untuk menyemak data dalam satu gelung untuk mencapai pengikatan dua hala

Seperti yang telah kami katakan di atas, biasanya tidak memanggil kaedah digest secara langsung, tetapi secara manual memanggil kaedah $apply untuk secara tidak langsung mencetuskan gelung $digest.

Seperti berikut:

setTimeout(function() {
 $scope.name= '一介布衣';
 $scope.$apply();
}, 2000);
Salin selepas log masuk
Masalahnya di sini, sudah tiba masanya untuk memanggil kaedah memohon secara manual

Setakat ini, angular.js telah melaksanakan kaedah $apply() secara automatik untuk beberapa arahan dan perkhidmatan.

Contohnya, ng-click, ng-model, perkhidmatan $timeout, perkhidmatan $http, dsb.


Selepas memanggil, angular.js akan memanggil $apply() secara automatik untuk kami mencapai pengikatan data dua hala.

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

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

Video Face Swap

Video Face Swap

Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Pengguna menghadapi gangguan yang jarang berlaku: Jam tangan pintar Samsung Watch tiba-tiba mengalami isu skrin putih Pengguna menghadapi gangguan yang jarang berlaku: Jam tangan pintar Samsung Watch tiba-tiba mengalami isu skrin putih Apr 03, 2024 am 08:13 AM

Anda mungkin menghadapi masalah garis hijau yang muncul pada skrin telefon pintar anda Walaupun anda tidak pernah melihatnya, anda mesti melihat gambar berkaitan di Internet. Jadi, pernahkah anda menghadapi situasi di mana skrin jam tangan pintar bertukar menjadi putih? Pada 2 April, CNMO mendapat tahu daripada media asing bahawa seorang pengguna Reddit berkongsi gambar di platform sosial, menunjukkan skrin jam tangan pintar siri Samsung Watch bertukar menjadi putih. Pengguna menulis: "Saya sedang mengecas apabila saya pergi, dan apabila saya kembali, ia adalah seperti ini. Saya cuba untuk memulakan semula, tetapi skrin masih seperti ini semasa proses mulakan semula skrin jam tangan pintar Samsung Watch." Pengguna Reddit tidak menyatakan model khusus. Walau bagaimanapun, jika dilihat dari gambar, ia sepatutnya Samsung Watch5. Sebelum ini, seorang lagi pengguna Reddit turut melaporkan

Bagaimana untuk memasang Angular pada Ubuntu 24.04 Bagaimana untuk memasang Angular pada Ubuntu 24.04 Mar 23, 2024 pm 12:20 PM

Angular.js ialah platform JavaScript yang boleh diakses secara bebas untuk mencipta aplikasi dinamik. Ia membolehkan anda menyatakan pelbagai aspek aplikasi anda dengan cepat dan jelas dengan memanjangkan sintaks HTML sebagai bahasa templat. Angular.js menyediakan pelbagai alatan untuk membantu anda menulis, mengemas kini dan menguji kod anda. Selain itu, ia menyediakan banyak ciri seperti penghalaan dan pengurusan borang. Panduan ini akan membincangkan cara memasang Angular pada Ubuntu24. Mula-mula, anda perlu memasang Node.js. Node.js ialah persekitaran berjalan JavaScript berdasarkan enjin ChromeV8 yang membolehkan anda menjalankan kod JavaScript pada bahagian pelayan. Untuk berada di Ub

Artikel yang meneroka pemaparan sisi pelayan (SSR) dalam Angular Artikel yang meneroka pemaparan sisi pelayan (SSR) dalam Angular Dec 27, 2022 pm 07:24 PM

Adakah anda tahu Angular Universal? Ia boleh membantu tapak web menyediakan sokongan SEO yang lebih baik!

Cara menggunakan PHP dan Angular untuk pembangunan bahagian hadapan Cara menggunakan PHP dan Angular untuk pembangunan bahagian hadapan May 11, 2023 pm 04:04 PM

Dengan perkembangan pesat Internet, teknologi pembangunan bahagian hadapan juga sentiasa bertambah baik dan berulang. PHP dan Angular ialah dua teknologi yang digunakan secara meluas dalam pembangunan bahagian hadapan. PHP ialah bahasa skrip sebelah pelayan yang boleh mengendalikan tugas seperti memproses borang, menjana halaman dinamik dan mengurus kebenaran akses. Angular ialah rangka kerja JavaScript yang boleh digunakan untuk membangunkan aplikasi satu halaman dan membina aplikasi web berkomponen. Artikel ini akan memperkenalkan cara menggunakan PHP dan Angular untuk pembangunan bahagian hadapan, dan cara menggabungkannya

Analisis ringkas tentang cara menggunakan editor monaco dalam sudut Analisis ringkas tentang cara menggunakan editor monaco dalam sudut Oct 17, 2022 pm 08:04 PM

Bagaimana untuk menggunakan monaco-editor dalam sudut? Artikel berikut merekodkan penggunaan monaco-editor dalam sudut yang digunakan dalam perniagaan baru-baru ini. Saya harap ia akan membantu semua orang!

Analisis ringkas komponen bebas dalam Angular dan lihat cara menggunakannya Analisis ringkas komponen bebas dalam Angular dan lihat cara menggunakannya Jun 23, 2022 pm 03:49 PM

Artikel ini akan membawa anda melalui komponen bebas dalam Angular, cara mencipta komponen bebas dalam Angular, dan cara mengimport modul sedia ada ke dalam komponen bebas saya harap ia akan membantu anda!

Cara data vue3 memantau watch/watchEffect Cara data vue3 memantau watch/watchEffect May 12, 2023 pm 06:31 PM

Kita semua tahu bahawa fungsi pendengar adalah untuk mencetuskan setiap kali keadaan reaktif berubah Dalam API gabungan, kita boleh menggunakan fungsi watch() dan fungsi watchEffect() Apabila anda menukar keadaan reaktif, ia mungkin dicetuskan pada masa yang sama. Kemas kini komponen Trigger Vue dan panggilan balik pendengar. Secara lalai, panggilan balik pendengar ciptaan pengguna akan dipanggil sebelum komponen Vue dikemas kini. Ini bermakna DOM yang anda akses dalam panggilan balik pendengar akan menjadi keadaan sebelum ia dikemas kini oleh Vue. Jadi, mari kita lihat, bagaimana kita boleh memanfaatkannya dengan baik? Apakah perbezaan antara mereka? Jam tangan fungsi watch() perlu mendengar sumber data tertentu, seperti mendengar rujukan Parameter pertama jam tangan boleh

Komponen sudut dan sifat paparannya: memahami lalai bukan blok Komponen sudut dan sifat paparannya: memahami lalai bukan blok Mar 15, 2024 pm 04:51 PM

Tingkah laku paparan lalai untuk komponen dalam rangka kerja Angular bukan untuk elemen peringkat blok. Pilihan reka bentuk ini menggalakkan pengkapsulan gaya komponen dan menggalakkan pembangun untuk secara sedar menentukan cara setiap komponen dipaparkan. Dengan menetapkan paparan sifat CSS secara eksplisit, paparan komponen Sudut boleh dikawal sepenuhnya untuk mencapai reka letak dan responsif yang diingini.

See all articles