Rumah hujung hadapan web tutorial js Pemahaman mendalam tentang siri JavaScript (28): Penjelasan terperinci tentang corak kilang corak reka bentuk_kemahiran javascript

Pemahaman mendalam tentang siri JavaScript (28): Penjelasan terperinci tentang corak kilang corak reka bentuk_kemahiran javascript

May 16, 2016 pm 04:11 PM
javascript Corak kilang corak reka bentuk

Pengenalan

Sama seperti corak ciptaan, corak kilang mencipta objek (dianggap sebagai produk di kilang) tanpa menyatakan kelas khusus objek yang akan dibuat.

Corak kilang mentakrifkan antara muka untuk mencipta objek Antara muka ini menentukan kelas mana yang hendak digunakan oleh subkelas. Corak ini menangguhkan instantiasi kelas kepada subkelas. Subkelas boleh mengatasi kaedah antara muka untuk menentukan jenis objek mereka sendiri semasa mencipta.

Mod ini sangat berguna, terutamanya apabila memberikan nilai kepada proses mencipta objek, seperti bergantung pada banyak fail tetapan. Selain itu, anda akan sering melihat kaedah kilang dalam program, yang digunakan untuk membenarkan subkelas menentukan jenis objek yang perlu dibuat.

Teks

Contoh berikut ialah versi peningkatan kod corak pembina dalam Bab 26 yang menggunakan kaedah kilang:

Salin kod Kod adalah seperti berikut:

var Kereta = (fungsi () {
var Kereta = fungsi (model, tahun, batu) {
This.model = model;
This.year = tahun;
This.miles = batu;
};
Fungsi kembali (model, tahun, batu) {
         pulangkan Kereta baharu(model, tahun, batu);
};
})();

var tom = Kereta baharu("Tom", 2009, 20000);
var dudu = Kereta baharu("Dudu", 2010, 5000);

Jika sukar untuk difahami, mari berikan anda satu lagi contoh:

Salin kod Kod adalah seperti berikut:

var productManager = {};

productManager.createProductA = fungsi () {
console.log('ProductA');
}

productManager.createProductB = fungsi () {
console.log('ProductB');
}
                             
productManager.factory = fungsi (typeType) {
Kembalikan productManager[typeType] baharu;
}

productManager.factory("createProductA");

Jika anda masih tidak faham, mari kita perincikan dengan lebih terperinci Katakan kita ingin memasukkan beberapa elemen ke dalam halaman web, dan jenis elemen ini mungkin berupa gambar, pautan atau teks. Mengikut Untuk mentakrifkan corak kilang, kita perlu mentakrifkan kelas kilang dan subkelas yang sepadan Mari kita tentukan pelaksanaan khusus subkelas (iaitu, subfungsi):

Salin kod Kod adalah seperti berikut:

halaman var = halaman ||. {};
page.dom = page.dom || {};
//Subfungsi 1: Teks proses
page.dom.Teks = fungsi () {
This.insert = fungsi (di mana) {
        var txt = document.createTextNode(this.url);
Where.appendChild(txt);
};
};

//Sub-fungsi 2: Memproses pautan
page.dom.Pautan = fungsi () {
This.insert = fungsi (di mana) {
        pautan var = document.createElement('a');
         pautan.href = this.url;
         link.appendChild(document.createTextNode(this.url));
Where.appendChild(pautan);
};
};

//Sub-fungsi 3: Memproses gambar
page.dom.Imej = fungsi () {
This.insert = fungsi (di mana) {
         var im = document.createElement('img');
          im.src = this.url;
Where.appendChild(im);
};
};

Jadi bagaimana kita mentakrifkan fungsi pemprosesan kilang? Ia sebenarnya sangat mudah:

Salin kod Kod adalah seperti berikut:

page.dom.factory = fungsi (jenis) {
Kembalikan page.dom[type] baharu;
}

Cara menggunakan:
Salin kod Kod adalah seperti berikut:

var o = page.dom.factory('Pautan');
o.url = 'http://www.cnblogs.com';
o.insert(document.body);

Pada ketika ini, saya percaya semua orang mempunyai pemahaman yang jelas tentang pengenalan kepada model kilang, jadi saya tidak akan menghuraikan lebih lanjut.

Ringkasan

Bila menggunakan corak kilang

Mod kilang amat berguna dalam senario berikut:

1. Pembinaan objek sangat rumit
2. Contoh yang berbeza perlu dibuat bergantung pada persekitaran khusus
3. Proseskan sejumlah besar objek kecil dengan sifat yang sama

Bila tidak menggunakan mod kilang

Jangan menyalahgunakan corak kilang Kadangkala ia hanya menambahkan kerumitan yang tidak perlu pada kod dan menyukarkan untuk menjalankan ujian.

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)

Apakah senario aplikasi corak kilang dalam rangka kerja java? Apakah senario aplikasi corak kilang dalam rangka kerja java? Jun 01, 2024 pm 04:06 PM

Corak kilang digunakan untuk memisahkan proses penciptaan objek dan merangkumnya dalam kelas kilang untuk memisahkannya daripada kelas konkrit. Dalam rangka kerja Java, corak kilang digunakan untuk: mencipta objek kompleks (seperti kacang dalam Spring), menyediakan pengasingan objek, meningkatkan kebolehujian dan kebolehselenggaraan, menyokong sambungan dan meningkatkan sokongan untuk jenis objek baharu dengan menambah kelas kilang baharu.

Perbezaan antara corak reka bentuk dan corak seni bina dalam rangka kerja Java Perbezaan antara corak reka bentuk dan corak seni bina dalam rangka kerja Java Jun 02, 2024 pm 12:59 PM

Dalam rangka kerja Java, perbezaan antara corak reka bentuk dan corak seni bina ialah corak reka bentuk mentakrifkan penyelesaian abstrak kepada masalah biasa dalam reka bentuk perisian, memfokuskan pada interaksi antara kelas dan objek, seperti corak kilang. Corak seni bina mentakrifkan hubungan antara struktur sistem dan modul, memfokuskan pada organisasi dan interaksi komponen sistem, seperti seni bina berlapis.

Analisis Corak Penghias dalam Corak Reka Bentuk Java Analisis Corak Penghias dalam Corak Reka Bentuk Java May 09, 2024 pm 03:12 PM

Corak penghias ialah corak reka bentuk struktur yang membolehkan penambahan dinamik fungsi objek tanpa mengubahsuai kelas asal. Ia dilaksanakan melalui kerjasama komponen abstrak, komponen konkrit, penghias abstrak dan penghias konkrit, dan boleh mengembangkan fungsi kelas secara fleksibel untuk memenuhi keperluan yang berubah-ubah. Dalam contoh ini, penghias susu dan mocha ditambahkan pada Espresso untuk jumlah harga $2.29, menunjukkan kuasa corak penghias dalam mengubah suai gelagat objek secara dinamik.

Analisis kes praktikal corak reka bentuk PHP Analisis kes praktikal corak reka bentuk PHP May 08, 2024 am 08:09 AM

1. Corak kilang: Asingkan penciptaan objek dan logik perniagaan, dan cipta objek jenis tertentu melalui kelas kilang. 2. Corak pemerhati: membenarkan objek subjek memberitahu objek pemerhati tentang perubahan keadaan mereka, mencapai gandingan longgar dan corak pemerhati.

Penggunaan indah corak penyesuai dalam corak reka bentuk Java Penggunaan indah corak penyesuai dalam corak reka bentuk Java May 09, 2024 pm 12:54 PM

Corak Penyesuai ialah corak reka bentuk struktur yang membolehkan objek yang tidak serasi berfungsi bersama Ia menukar satu antara muka kepada yang lain supaya objek boleh berinteraksi dengan lancar. Penyesuai objek melaksanakan corak penyesuai dengan mencipta objek penyesuai yang mengandungi objek yang disesuaikan dan melaksanakan antara muka sasaran. Dalam kes praktikal, melalui mod penyesuai, pelanggan (seperti MediaPlayer) boleh memainkan media format lanjutan (seperti VLC), walaupun ia sendiri hanya menyokong format media biasa (seperti MP3).

Bagaimana corak reka bentuk menangani cabaran penyelenggaraan kod Bagaimana corak reka bentuk menangani cabaran penyelenggaraan kod May 09, 2024 pm 12:45 PM

Corak reka bentuk menyelesaikan cabaran penyelenggaraan kod dengan menyediakan penyelesaian yang boleh digunakan semula dan boleh diperluas: Corak Pemerhati: Membenarkan objek melanggan acara dan menerima pemberitahuan apabila ia berlaku. Corak Kilang: Menyediakan cara terpusat untuk mencipta objek tanpa bergantung pada kelas konkrit. Corak Singleton: memastikan bahawa kelas hanya mempunyai satu contoh, yang digunakan untuk mencipta objek yang boleh diakses secara global.

Corak Reka Bentuk PHP: Pembangunan Dipacu Ujian dalam Amalan Corak Reka Bentuk PHP: Pembangunan Dipacu Ujian dalam Amalan Jun 03, 2024 pm 02:14 PM

TDD digunakan untuk menulis kod PHP berkualiti tinggi Langkah-langkahnya termasuk: menulis kes ujian, menerangkan fungsi yang diharapkan dan menjadikannya gagal. Tulis kod supaya hanya kes ujian lulus tanpa pengoptimuman yang berlebihan atau reka bentuk terperinci. Selepas kes ujian lulus, optimumkan dan faktorkan semula kod untuk meningkatkan kebolehbacaan, kebolehselenggaraan dan kebolehskalaan.

Aplikasi corak reka bentuk dalam rangka kerja Guice Aplikasi corak reka bentuk dalam rangka kerja Guice Jun 02, 2024 pm 10:49 PM

Rangka kerja Guice menggunakan beberapa corak reka bentuk, termasuk: Corak Singleton: memastikan kelas hanya mempunyai satu tika melalui anotasi @Singleton. Corak kaedah kilang: Cipta kaedah kilang melalui anotasi @Provides dan dapatkan contoh objek semasa suntikan pergantungan. Mod strategi: Bungkus algoritma ke dalam kelas strategi yang berbeza dan nyatakan strategi khusus melalui anotasi @Named.

See all articles