Jadual Kandungan
Apakah suntikan kebergantungan?
Rangka kerja DI Angular
1. Cipta penyuntik
总结
Rumah hujung hadapan web tutorial js Apakah suntikan pergantungan? Bagaimana untuk melaksanakannya dalam Angular?

Apakah suntikan pergantungan? Bagaimana untuk melaksanakannya dalam Angular?

Feb 02, 2022 am 09:00 AM
angular di suntikan pergantungan

Artikel ini akan memperkenalkan anda kepada suntikan pergantungan, memperkenalkan masalah yang diselesaikan dengan suntikan pergantungan dan kaedah penulisan asalnya, dan bercakap tentang rangka kerja suntikan pergantungan Angular Saya harap ia akan membantu semua orang!

Apakah suntikan pergantungan? Bagaimana untuk melaksanakannya dalam Angular?

Baru-baru ini, saya sering menjumpai suntikan ketergantungan kata kunci dalam projek Angular, tetapi saya masih tidak faham bagaimana ia dilaksanakan hanya pada Angular's ​​laman web rasmi Prinsip penggunaan tidak diterangkan secara terperinci, jadi mari kita jelaskan dari kaedah penulisan asli Apakah masalah yang digunakan untuk menyelesaikan masalah ini menggunakan js. [Cadangan tutorial berkaitan: "tutorial sudut"]

Apakah suntikan kebergantungan?

Suntikan kebergantungan, dirujuk sebagai DI, ialah prinsip reka bentuk dalam pengaturcaraan berorientasikan objek . Kurangkan gandingan antara kod.

Mari kita lihat sekeping kod dahulu

class Video{
    constructor(url){}
}

class Note{
    video: Video
    constructor(){
        this.video = new Video("https://aaaaa.mp4")
    }
    
    getScreenshot(){
        this.video.getScreenshot()
    }
}

const note = new Note()
note.getScreenshot()
Salin selepas log masuk

Andaikan kita menggunakan kelas video, yang mempunyai kaedah getScreenshot untuk mendapatkan tangkapan skrin semasa membuat seketika kelas video, video perlu diluluskan dalam parameter url. Sekarang terdapat kelas nota, yang perlu memanggil kaedah tangkapan skrin di bawah kelas video Kemudian kita boleh mengatakan bahawa kelas nota bergantung pada kelas video. Jadi di dalam kelas nota, kita perlu membuat instantiate kelas video, supaya kita boleh mendapatkan objek contoh kelas video dalam kelas nota dan memanggil kaedah tangkapan skrin di dalamnya.

Gandingan kod di atas adalah terlalu tinggi dan tidak disyorkan Contohnya, jika alamat video Video ditukar, maka url video masuk perlu ditukar dalam Nota lagi Kelas bergantung pada kelas video, jadi sebaik sahaja perubahan dibuat, semuanya mesti diubah sewajarnya, yang sangat menyusahkan.

Seterusnya, suntikan kebergantungan digunakan untuk menyelesaikan masalah di atas:

class Note{
    video: Video
    constructor(video: Video){
        this.video = Video;
    }
}

const video = new Video("https://aaaaa.mp4")
const note = new Note(video)
Salin selepas log masuk

Kami membuat instantiate kelas video di luar kelas dan menghantar contoh kepada kelas nota melalui hantaran parameter cara, masalah gandingan yang berlebihan boleh berjaya diselesaikan Kami memanggil kaedah ini melalui parameter: suntikan.

Kelebihan

Suntikan kebergantungan mengurangkan gandingan antara kod dan meningkatkan kebolehselenggaraan kod. Perubahan kod dalam kelas video tidak akan menjejaskan kelas nota.

Rangka kerja DI Angular

Dalam proses pelaksanaan di atas, masih terdapat satu perkara yang tidak begitu ideal, iaitu, kita perlu membuat instantiate kelas video di luar kelas, walaupun ini adalah satu-satunya tempat , tetapi kami masih berharap bahawa tidak kira bagaimana perubahan dalaman kelas video ditukar, kod luaran tidak akan terjejas.

Dalam rangka kerja DI yang disediakan oleh Angular, kita tidak perlu membuat instantiat kelas video itu sendiri. Ia menyembunyikan proses suntikan pergantungan Untuk pembangun, mereka hanya perlu menggunakan kod yang sangat mudah kemudiannya kefungsian suntikan pergantungan.

Terdapat empat konsep teras dalam DI Angular:

  • Kebergantungan: objek contoh yang komponen bergantung, objek contoh perkhidmatan

  • Token: Dapatkan pengecam objek contoh perkhidmatan Angular akan mengekalkan banyak objek contoh. Apabila kita perlu mendapatkannya, kita perlu mendapatkannya melalui pengecam , bertanggungjawab untuk mencipta dan mengekalkan objek contoh kelas perkhidmatan, menyuntik objek contoh perkhidmatan ke dalam komponen, dan menghantarnya kepada setiap komponen melalui parameter

  • Procider: objek, digunakan untuk mengkonfigurasi penyuntik, ditentukan Cipta kelas perkhidmatan objek instance perkhidmatan dan dapatkan pengecam objek instance

  • Injector injector

  • Kami mula-mula mencipta injector melalui sintaks asas yang disediakan oleh Angular

1. Cipta penyuntik

Perkenalkan ReflectiveInjector Kaedah resolveAndCreate digunakan untuk membuat penyuntik Kaedah ini akan mengembalikan penyuntik. 2. Dapatkan objek contoh kelas perkhidmatan dalam penyuntik

import { ReflectiveInjector } from "@angular/core"
//服务类
class Video{}
//创建注入器并传入服务类
const injector = ReflectiveInjector.resolveAndCreate([ Video ])
Salin selepas log masuk
Terdapat kaedah dapatkan di bawah penyuntik, yang digunakan untuk lulus dalam pengecam dan mendapatkan objek tikar Pengecam lalai ialah nama kelas perkhidmatan, iaitu Video

Dengan cara ini, kita boleh mendapatkan objek contoh Video Rangka kerja DI yang disediakan oleh Angular menjadikannya tidak perlu untuk membuat kelas secara manual untuk mendapatkan objek contohnya buat untuk kita.
const video = injector.get(Video)
Salin selepas log masuk

2. Objek contoh perkhidmatan berada dalam mod tunggal Penyuntik menyesali menyimpannya selepas mencipta contoh perkhidmatan

Dengan kata lain, tidak kira berapa kali objek contoh. diperoleh melalui rangka kerja, Ia mengembalikan objek contoh yang sama

3 Tetapi kita boleh mencipta berbilang penyuntik. >4. Terdapat kaedah untuk membuat penyuntik kanak-kanak pada penyuntik yang dipanggil resolveAndCreateChild Kaedah ini akan mewujudkan penyuntik kanak-kanak Hubungan antara penyuntik induk dan penyuntik anak adalah serupa dengan rantaian skop js ditemui, ia akan mencari penyuntik induk, seperti:
const video1 = injector.get(Video)
const video2 = injector.get(Video)

console.log(video1 === video1)//true
Salin selepas log masuk
const injector = ReflectiveInjector.resolveAndCreate([ Video ])
const injectorChild = injector.resolveAndCreateChild([])

const video1 = injector.get(Video)
const video2 = injectorChild.get(Video)

console.log(video1 === video1)//true
Salin selepas log masuk

像上面这段代码,我们在创建子级注入器的时候,不传递参数,但是在子级注入器实例化的时候,由于自身不存在 Video 这个服务,它就会去父级查找,当然,就找到了父级的 Video 这个服务并且实例化,所以后面的两个实例化对象相等

总结

本文介绍了依赖注入解决的问题和它原生的写法是什么用的,并且介绍了Angular提供给我们的DI框架,用它提供给我们的简单api实现了实例化的过程,并且讲解了注入器,也是会分层级的,能提供给我们更好地一个项目设计方式。之后有机会再来讲解一下provider以及更多的扩展。

更多编程相关知识,请访问:编程视频!!

Atas ialah kandungan terperinci Apakah suntikan pergantungan? Bagaimana untuk melaksanakannya dalam Angular?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

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

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

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)

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!

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.

Apakah yang perlu saya lakukan jika projek itu terlalu besar? Bagaimana untuk membahagikan projek Angular dengan munasabah? Apakah yang perlu saya lakukan jika projek itu terlalu besar? Bagaimana untuk membahagikan projek Angular dengan munasabah? Jul 26, 2022 pm 07:18 PM

Projek Angular terlalu besar, bagaimana untuk membahagikannya secara munasabah? Artikel berikut akan memperkenalkan kepada anda cara membahagikan projek Angular secara munasabah. Saya harap ia akan membantu anda!

Mari kita bincangkan tentang cara mendapatkan data terlebih dahulu dalam Laluan Sudut Mari kita bincangkan tentang cara mendapatkan data terlebih dahulu dalam Laluan Sudut Jul 13, 2022 pm 08:00 PM

Bagaimana untuk mendapatkan data terlebih dahulu dalam Laluan Sudut? Artikel berikut akan memperkenalkan kepada anda cara mendapatkan data terlebih dahulu dari Laluan Sudut Saya harap ia akan membantu anda!

See all articles