Ujian AngularJS: Blok Bootstrap, Laluan, Acara, dan Animasi
Feb 19, 2025 am 10:12 AM
mata utama
- Ujian unit adalah kritikal untuk pembangunan perisian, terutamanya untuk aplikasi yang mengandungi beratus -ratus ribu baris kod JavaScript. AngularJS menyokong ciri -ciri seperti suntikan ketergantungan (DI) untuk membuat ujian kod lebih mudah.
- Konfigurasi dan blok berjalan dilaksanakan pada permulaan kitaran hayat modul dan mengandungi logik penting. Mereka tidak boleh dipanggil secara langsung seperti komponen lain, yang membuat ujian mereka rumit, tetapi kerana peranan kritikal mereka, mereka tidak boleh diabaikan.
- AngularJS menyediakan agregasi peristiwa melalui acara
- pada
$scope
, yang membolehkan objek berinteraksi antara satu sama lain walaupun mereka tidak tahu tentang satu sama lain. Ujian unit ditulis secara berasingan, jadi spesifikasi ujian perlu mensimulasikan satu hujung untuk menguji fungsi.$emit/$broadcast
Routing mentakrifkan bagaimana pengguna menavigasi dalam aplikasi, dan sebarang perubahan boleh membawa kepada pengalaman pengguna yang buruk. Oleh itu, penghalaan juga harus diuji. Kedua-dua router yang paling biasa digunakan dalam aplikasi AngularJS adalah ngroute dan ui-router. - Menguji animasi dalam AngularJs adalah lebih mudah daripada arahan ujian, dan perpustakaan
- mengandungi modul
angular-mocks
untuk memudahkan proses ini. AngularJS menghalang animasi dari berjalan sehingga gelung pencernaan pertama selesai untuk mempercepatkan pengikatan awal.ngAnimateMock
Konfigurasi ujian dan blok jalan
Konfigurasi dan blok berjalan dilaksanakan pada permulaan kitaran hayat modul. Mereka mengandungi logik penting untuk mengawal bagaimana modul, widget, atau aplikasi berfungsi. Menguji mereka agak rumit kerana mereka tidak boleh dipanggil secara langsung seperti komponen lain. Pada masa yang sama, mereka tidak boleh diabaikan kerana peranan mereka adalah penting. Pertimbangkan konfigurasi berikut dan blok berjalan:angular.module('configAndRunBlocks', ['ngRoute']) .config(function ($routeProvider) { $routeProvider.when('/home', { templateUrl: 'home.html', controller: 'HomeController', resolve: { bootstrap: ['$q', function ($q) { return $q.when({ prop: 'value' }); }] } }) .when('/details/:id', { templateUrl: 'details.html', controller: 'DetailsController' }) .otherwise({ redirectTo: '/home' }); }) .run(function ($rootScope, messenger) { messenger.send('Bootstrapping application'); $rootScope.$on('$locationChangeStart', function (event, next, current) { messenger.send('Changing route to ' + next + ' from ' + current); }); });
Sama seperti kes dengan pembekal ujian, kita perlu memastikan bahawa modul dimuatkan sebelum menguji konfigurasi dan menjalankan fungsi di blok. Oleh itu, kami akan menggunakan blok suntikan kosong untuk memuatkan modul. Coretan kod berikut mensimulasikan kebergantungan yang digunakan dalam blok di atas dan memuat modul:
describe('config and run blocks', function () { var routeProvider, messenger; beforeEach(function () { module('ngRoute'); module(function ($provide, $routeProvider) { routeProvider = $routeProvider; spyOn(routeProvider, 'when').andCallThrough(); spyOn(routeProvider, 'otherwise').andCallThrough(); messenger = { send: jasmine.createSpy('send') }; $provide.value('messenger', messenger); }); module('configAndRunBlocks'); }); beforeEach(inject()); });
Saya sengaja tidak mensimulasikan objek $routeProvider
kerana kami akan menguji laluan berdaftar dalam artikel ini kemudian. Modul kini dimuatkan, blok konfigurasi dan larian dilaksanakan. Jadi kita boleh mula menguji tingkah laku mereka. Oleh kerana blok konfigurasi mendaftarkan laluan, kita boleh menyemak sama ada ia mendaftarkan laluan yang betul. Kami akan menguji sama ada bilangan laluan yang dijangkakan didaftarkan. Ujian berikut mengesahkan fungsi blok konfigurasi:
describe('config block tests', function () { it('should have called registered 2 routes', function () { //Otherwise internally calls when. So, call count of when has to be 3 expect(routeProvider.when.callCount).toBe(3); }); it('should have registered a default route', function () { expect(routeProvider.otherwise).toHaveBeenCalled(); }); });
Blok lari dalam kod sampel memanggil perkhidmatan dan mendaftarkan acara. Kami akan menguji acara ini kemudian dalam artikel ini. Pada masa ini, mari kita menguji panggilan ke kaedah perkhidmatan:
describe('run block tests', function () { var rootScope; beforeEach(inject(function ($rootScope) { rootScope = $rootScope; })); it('should send application bootstrap message', function () { expect(messenger.send).toHaveBeenCalled(); expect(messenger.send).toHaveBeenCalledWith("Bootstrapping application"); }); });
(Penerangan berikutnya mengenai peristiwa skop ujian, penghalaan, blok parsing dan animasi ditinggalkan di sini kerana batasan ruang. Untuk contoh kod ujian lengkap, sila rujuk repositori GitHub asal)
Kesimpulan
Melalui artikel ini, saya memperkenalkan kebanyakan teknik ujian yang saya pelajari dalam menguji kod AngularJS sejak dua tahun yang lalu. Ini bukan akhir, dan anda akan belajar lebih banyak apabila anda menulis ujian untuk senario perniagaan aplikasi sebenar anda. Saya harap anda kini mendapat pengetahuan yang cukup untuk menguji kod AngularJS. Kenapa tunggu? Tulis ujian untuk setiap baris kod yang saya tulis setakat ini!
Atas ialah kandungan terperinci Ujian AngularJS: Blok Bootstrap, Laluan, Acara, dan Animasi. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Alat AI Hot

Undress AI Tool
Gambar buka pakaian secara percuma

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Clothoff.io
Penyingkiran pakaian AI

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

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas

Java dan JavaScript adalah bahasa pengaturcaraan yang berbeza, masing -masing sesuai untuk senario aplikasi yang berbeza. Java digunakan untuk pembangunan aplikasi perusahaan dan mudah alih yang besar, sementara JavaScript digunakan terutamanya untuk pembangunan laman web.

JavaScriptcommentsareessentialformaintaining,reading,andguidingcodeexecution.1)Single-linecommentsareusedforquickexplanations.2)Multi-linecommentsexplaincomplexlogicorprovidedetaileddocumentation.3)Inlinecommentsclarifyspecificpartsofcode.Bestpractic

Titik berikut harus diperhatikan apabila tarikh pemprosesan dan masa di JavaScript: 1. Terdapat banyak cara untuk membuat objek tarikh. Adalah disyorkan untuk menggunakan rentetan format ISO untuk memastikan keserasian; 2. Dapatkan dan tetapkan maklumat masa boleh diperoleh dan tetapkan kaedah, dan ambil perhatian bahawa bulan bermula dari 0; 3. Tarikh pemformatan secara manual memerlukan rentetan, dan perpustakaan pihak ketiga juga boleh digunakan; 4. Adalah disyorkan untuk menggunakan perpustakaan yang menyokong zon masa, seperti Luxon. Menguasai perkara -perkara utama ini secara berkesan dapat mengelakkan kesilapan yang sama.

JavaScriptispreferredforwebdevelopment, whersjavaisbetterforlarge-scalebackendsystemsandandroidapps.1) javascriptexcelsinceleatinginteractiveWebexperienceswithitsdynamicnatureanddommanipulation.2) javaoffersstrongyblectionandobjection

PlacingtagsatthebottomofablogpostorwebpageservespracticalpurposesforSEO,userexperience,anddesign.1.IthelpswithSEObyallowingsearchenginestoaccesskeyword-relevanttagswithoutclutteringthemaincontent.2.Itimprovesuserexperiencebykeepingthefocusonthearticl

JavascripthassevenfundamentalDatypes: nombor, rentetan, boolean, undefined, null, objek, andsymbol.1) numberuseadouble-precisionformat, bergunaforwidevaluangesbutbecautiouswithfloating-pointarithmetic.2)

Penangkapan dan gelembung acara adalah dua peringkat penyebaran acara di Dom. Tangkap adalah dari lapisan atas ke elemen sasaran, dan gelembung adalah dari elemen sasaran ke lapisan atas. 1. Penangkapan acara dilaksanakan dengan menetapkan parameter useCapture addeventlistener kepada benar; 2. Bubble acara adalah tingkah laku lalai, useCapture ditetapkan kepada palsu atau ditinggalkan; 3. Penyebaran acara boleh digunakan untuk mencegah penyebaran acara; 4. Acara menggelegak menyokong delegasi acara untuk meningkatkan kecekapan pemprosesan kandungan dinamik; 5. Penangkapan boleh digunakan untuk memintas peristiwa terlebih dahulu, seperti pemprosesan pembalakan atau ralat. Memahami kedua -dua fasa ini membantu mengawal masa dan bagaimana JavaScript bertindak balas terhadap operasi pengguna.

Java dan JavaScript adalah bahasa pengaturcaraan yang berbeza. 1.Java adalah bahasa yang ditaip dan disusun secara statik, sesuai untuk aplikasi perusahaan dan sistem besar. 2. JavaScript adalah jenis dinamik dan bahasa yang ditafsirkan, terutamanya digunakan untuk interaksi web dan pembangunan front-end.
