gpt4 book ai didi

javascript - 工厂方法/类模式的继承

转载 作者:行者123 更新时间:2023-11-30 07:21:02 24 4
gpt4 key购买 nike

我正在阅读有关在 JavaScript 中创建对象的不同方法,而不是使用 new 和 ES6 类。一种方法是使用工厂方法/工厂类模式(取自 https://medium.com/humans-create-software/factory-functions-in-javascript-video-d38e49802555 ):

const dog = () => {
const sound = 'woof'
return {
talk: () => console.log(sound)
}
}
const sniffles = dog()
sniffles.talk() // Outputs: "woof"

我将如何实现像 Animal 这样的类,或者我的 dog 函数可以从中“继承”的另一个工厂函数?我是否会将动物对象传递给 dog 函数并将要返回的对象的原型(prototype)设置为传递的动物对象?

最佳答案

您将使用 Object.create:

const animal = () => ({
talk: function() {
console.log(this.sound);
}
});

const dog = () => Object.create(animal(), {
sound: {
value: "woof"
}
});

// or...

const dog2 = () => {
var someDog = Object.create(animal());
someDog.sound = "woof";

return someDog;
};

var someDog = dog();
someDog.talk();

var someDog2 = dog2();
someDog2.talk();

顺便说一句,我的意见是你应该使用 ES2015+ 类/继承,并在你真正需要它们的极端情况下保留自定义工厂和 Object.create 的使用:

class Animal {
talk() {
return console.log(this.sound);
}
}

class Dog extends Animal {
constructor() {
super();
this.sound = "woof";
}
}

var dog = new Dog();
dog.talk();

关于javascript - 工厂方法/类模式的继承,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43864114/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com