我有两种形式的页面。我在顶部有一个A型的单一形式,然后我有一个或多个B型的形式。Javascript模块模式可以用于单身人士,还可以用于实例化多次的对象吗?
我用模块模式+ jQuery来连线了所有的事件上我的形式,处理验证,AJAX调用等
这是定义一个单,如形式A的最佳/有效的方式,和一个可重用的对象类,如Form B?他们非常相似,我不确定是否需要使用对象prototype
属性,new
或其他模式。一切似乎都适用于我,但我担心我错过了一些关键错误。
Form A
的JavaScript看起来像这样:
var MyProject.FormA = (function() {
var $_userEntry;
var $_domElementId;
var validate = function() {
if($_userEntry == 0) {
alert('Cannot enter 0!');
}
}
var processUserInput = function() {
$_userEntry = jQuery('inputfield', $_domElementId).val();
validate();
}
return {
initialize: function(domElementId) {
$_domElementId = domElementId;
jQuery($_domElementId).click(function() {
processUserInput();
}
}
}
})();
jQuery(document).ready(function() {
MyProject.FormA.initialize('#form-a');
});
Form B
,这是初始化一个或多次,是指像这样:
var MyProject.FormB = function() {
var $_userEntry;
var $_domElement;
var validate = function() {
if($_userEntry == 0) {
alert('Cannot enter 0!');
}
}
var processUserInput = function() {
$_userEntry = jQuery('inputfield', $_domElement).val();
validate();
}
return {
initialize: function(domElement) {
$_domElement = domElement;
jQuery($_domElement).click(function() {
processUserInput();
}
}
}
};
jQuery(document).ready(function() {
jQuery(".form-b").each(function() {
MyProject.FormB().initialize(this);
});
});