Üretici Çalışma Bağlamı
Bir Üretici yazarken kavraması gereken en önemli kavramlardan biri, yöntemlerin nasıl çalıştığı ve hangi bağlamda bulunduğudur.
Prototip yöntemleri eylem olarak
Bir Üretici prototipine doğrudan bağlı her yöntem, bir görev olarak kabul edilir. Her görev, Yeoman ortamı çalıştırma döngüsü tarafından sırayla çalıştırılır.
Not: Diğer bir deyişle,
Object.getPrototypeOf(Generator)
ile döndürülen nesnedeki her fonksiyon otomatik olarak çalıştırılacaktır.
Yardımcı ve özel yöntemler
Prototip yöntemlerinin bir görev olarak kabul edildiğini bildiğinize göre, otomatik olarak çağrılmayacak yardımcı veya özel yöntemleri nasıl tanımlayacağınızı merak edebilirsiniz. Bunu başarmanın üç farklı yolu vardır.
Yöntem adını bir alt çizgi ile öne alın (örneğin,
_private_method
).class extends Generator {
method1() {
console.log('hey 1');
}
_private_method() {
console.log('özel hey');
}
}Örnek yöntemlerini kullanın:
class extends Generator {
constructor(args, opts) {
// Süper yapıcıyı çağırmak, üreticimizin doğru şekilde ayarlandığından emin olmak için önemlidir
super(args, opts)
this.helperMethod = function () {
console.log('otomatik olarak çağrılmayacak');
};
}
}Bir üst üreticiyi genişletin:
class MyBase extends Generator {
helper() {
console.log('üst üreticideki yöntemler otomatik olarak çağrılmayacak');
}
}
module.exports = class extends MyBase {
exec() {
this.helper();
}
};
Çalışma döngüsü
Görevleri sırayla çalıştırmak, tek bir üretici için uygundur. Ancak, üreticileri birlikte birleştirmeye başladığınızda yeterli değildir.
Bu nedenle Yeoman bir çalışma döngüsü kullanır. Çalışma döngüsü, öncelik desteği olan bir kuyruk sistemidir. Çalışma döngüsünü yönetmek için Grouped-queue modülünü kullanıyoruz.
Öncelikler, kodunuzda özel prototip yöntemi adları olarak tanımlanır. Bir yöntem adı bir öncelik adıyla aynı olduğunda, çalışma döngüsü bu yöntemi özel kuyruğa ekler. Eğer yöntem adı bir öncelikle eşleşmiyorsa, default
grubuna eklenir.
Kodda bu şekilde görünecektir:
class extends Generator {
priorityName() {}
}
Ayrıca, bir hash kullanarak bir kuyruğa birlikte çalıştırılacak birden fazla yöntemi gruplayabilirsiniz:
Generator.extend({
priorityName: {
method() {},
method2() {}
}
});
(Bu son teknik, JS class
tanımıyla pek iyi çalışmaz)
Mevcut öncelikler (çalıştırma sırasına göre) şunlardır:
initializing
- Başlatma yöntemleriniz (mevcut proje durumunu kontrol etme, yapılandırmaları alma, vb.)prompting
- Kullanıcılardan seçenekler için ipucu verdiğiniz yer (buradathis.prompt()
çağırırsınız)configuring
- Yapılandırmaları kaydetme ve projeyi yapılandırma (.editorconfig
dosyaları ve diğer meta veri dosyaları yaratma)default
- Yöntem adı bir öncelikle eşleşmiyorsa, bu gruba eklenir.writing
- Üreticiye özgü dosyaları yazdığınız yer (yollar, kontrolörler, vb.)conflicts
- Çatışmaların yönetildiği yer (içsel olarak kullanılır)install
- Kurulumların yapıldığı yer (npm, bower)end
- Son çağrıldığında, temizlik, hoşçakal demek, vb.
Bu öncelikler kılavuzlarına uyun ve üreticiniz diğerleriyle uyumlu çalışacaktır.
Asenkron görevler
Bir görevin asenkron olarak tamamlanmasını beklemek için çalışma döngüsünü durdurmanın birçok yolu vardır.
En kolay yol bir promise döndürmektir. Promise çözüldüğünde döngü devam eder veya bir istisna yükselterek durur eğer başarısız olursa.
Kullandığınız asenkron API promise'leri desteklemiyorsa, o zaman eski this.async()
yoluna güvenebilirsiniz. this.async()
çağırmak, görev tamamlandığında çağrılması gereken bir fonksiyon döndürür. Örneğin:
asyncTask() {
var done = this.async();
getUserEmail(function (err, name) {
done(err);
});
}
done
fonksiyonu bir hata parametresi ile çağrıldığında, çalışma döngüsü durur ve bir istisna yükseltilir.
Buradan nereye?
Artık yeoman'ın çalışma bağlamı hakkında biraz daha fazla şey bildiğinize göre, kullanıcı etkileşimleri
konusunu okumaya devam edebilirsiniz.