如何避免重复的JS代码,每个使用自己的这个?



我有几个具有相同重复代码的不同类。除了每个this的身份不同之外,这些重复的代码表面上都是相同的。

下面是一个简化的例子:

class classA {
...
doSomething() {
if (!this.id || !this.data || !this.isAllowed()) {
return null;
}
return someImportedFunc(this.data, this.metadata, this.doSomethingElse());
}
}
class classB {
...
doSomething() {
if (!this.id || !this.data || !this.isAllowed()) {
return null;
}
return someImportedFunc(this.data, this.metadata, this.doSomethingElse());
}
}
// Many other classes like this

我想把doSomething方法移动到另一个类,然后在所有这些类中导入它。但是这将导致一个非常混乱的方法,需要很多很多的参数来解释所有不同的this

class exportedClass {
function doSomething(id, data, metadata, isAllowed, doSomethingElse) {
if (!id || !data || !isAllowed()) {
return null;
}
return someImportedFunc(data, metadata, doSomethingElse());
}
}
class classA {
...
methodThatUsesDoSomething() {
const result = exportedClass.doSomething(
this.id, this.data, this.metadata, this.isAllowed, this.doSomethingElse);
...
}
}

除了有15个参数而不是5个,因为这是一个简化的例子。

在这种情况下,我如何避免重复的代码?

假设你想要一个非继承的解决方案,我的建议是传递"this"作为一个参数,原型可以作为参数来操作。这将允许您在不丢失数据的情况下将参数保持在最小值。

相关内容

最新更新