用JavaScript编写对象方法的最佳方式是什么
What is the best way to write object methods in JavaScript?
OOP建议只公开您希望用户能够访问的变量和方法。我一直在为我的对象使用公共方法声明(即原型)。
DrawShape = function() {
}
DrawShape.prototype.circle = function() {
// draw logic here
}
DrawShape.prototype.square = function() {
// draw logic here
}
这个方法似乎是最有效的,因为该方法不是每次实例化实例时都重写的。然而,我发现,为了创建好的DRY、模块化代码,我必须创建只供其他方法(即私有方法)访问的方法。
DrawShape = function() {
}
DrawShape.prototype.circle = function() {
var colour = this.setColour();
// draw logic here
}
DrawShape.prototype.square = function() {
var colour = this.setColour();
// draw logic here
}
DrawShape.prototype.setColour = function() {
return "blue";
}
在这里,我创建了一个名为setColour的方法,它只打算由其他方法运行。问题是该方法是公开的,任何人或任何东西都可以调用它。
我可以将该方法移到对象构造函数中。。。但这意味着我不再节省内存(即,每次实例化实例时都会重写内存),也意味着我必须将所有其他方法移到构造函数中。
在创建对象时,JavaScript的最佳实践是什么?
IIFE(立即调用函数表达式)的威力:
DrawShape = function() {
}
(function () {
DrawShape.prototype.circle = function() {
var colour = setColour();
// draw logic here
console.log(typeof setColour); // function
}
DrawShape.prototype.square = function() {
var colour = setColour();
// draw logic here
console.log(typeof setColour); // function
}
function setColour() {
return "blue";
}
console.log(typeof setColour); // function
})();
console.log(typeof setColour); // undefined
注意,如果在setColour
函数中使用this
,则必须使用当前值this
来调用它,因为您无法合理地将this
绑定到特定对象(据我所知,即使是ES6也无法使其变得更容易):
setColour.call(this);
不管怎样,那些"u"一定伤害了美国人的眼睛
我更喜欢这个:
DrawShape = function() {
var circle = function() {
var colour = setColour();
// draw logic here
};
var square = function() {
var colour = setColour();
// draw logic here
};
var setColour = setColour() {
return "blue";
};
return {
circle: circle,
square: square
};
};
我觉得它看起来不错。准备好也很好。
编辑:
根据评论,我们可以重写如下:
DrawShape = function() {
this.circle = function() {
var colour = setColour();
// draw logic here
};
this.square = function() {
var colour = setColour();
// draw logic here
};
var setColour = setColour() {
return "blue";
};
return this;
};
我真的不喜欢IIFC。
相关文章:
- 在localhost Dev Box上测试JSONP请求的最佳方式
- 为react组件传递道具的最佳方式
- 让Webpack管理Quirky AMD定义的最佳方式
- 在承诺链中处理早期回报的最佳方式
- 在ng重复循环中显示条件内容的最佳方式是什么
- 在phonegap中为android调用onload函数的最佳方式
- 链接两个网页或网络应用程序的最佳方式
- 什么's是连接供应商js文件的最佳方式
- 什么's是在javascript中迭代项的最佳方式
- 在node.js中编写单元测试的最佳方式是什么
- 在页面上记录数据并实现pushstate()的最佳方式
- 使用AJAX在Rails中提交动态表单的最佳方式是什么
- 什么'这是加载jQuery的最佳方式
- 将大数组(字符串和类型数组的混合物)存储到blob或文件中/从blob或文件检索大数组的最佳方式
- 在网站上显示.mov作为加载屏幕的最佳方式
- 使用Angular存储用户以前是否选中过复选框,然后再调用它的最佳方式是什么
- 以角度渲染表中数据的最佳方式
- 删除集合中旧邮件/帖子的最佳方式
- 显示全屏Ajax加载程序的最佳方式
- PHP和JS中表单验证的最佳方式