- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
在使用了一些验证库之后,我最终决定推出自己的实现,因为没有一个库的行为符合我想要的方式。下面的代码工作正常,但我认为它不是很惯用。函数体很大,可能应该重构为更小的 block 。
我确信有很多方法可以改进我的代码,但我正在寻求有关如何将大函数分解为更小的函数的具体建议,以便代码更容易理解。显然我想添加更多的验证函数,并且我不想创建一堆意大利面条。
验证应该在元素的模糊
上进行。通过插入和删除 div
,用户会收到问题通知。
验证函数:
(function($) {
$.fn.extend({
live_validate: function() {
return this.each(function() {
var inputs = $('input', $(this));
inputs.blur(function() {
var el = $(this);
el.siblings('div.feedback').remove();
if(el.hasAttr('required') && el.val() == '') {
el.after('<div class="feedback feedback-error">must be present</div>');
return;
}
if(el.hasAttr('minlength') && el.val().length < el.attr('minlength')) {
el.after('<div class="feedback feedback-error">is too small</div>');
return;
}
// no validation returned; all good.
el.filter(":visible").after('<div class="feedback feedback-ok"></div>');
});
});
}
});
})(jQuery);
这是我用来检查属性是否存在的快速助手。我需要知道该属性是否存在。有更好的方法吗?
$.fn.hasAttr = function(name) {
return (this.attr(name) !== undefined && this.attr(name) !== false);
};
最后,在我想要的表单上调用验证器。
$(document).ready(function() {
$("form.new_user").live_validate();
}
最佳答案
我会将每个验证器分隔在其自己的函数中,将每个逻辑分隔在另一个函数中。
(function($) {
var validators = {
required: function(el) {
// Validation code...
},
minlength: function(el) {
// Validation code...
} // you can add more validators here..
};
$.fn.extend({
live_validate: function(enabledValidators) {
return this.each(function() {
var inputs = $('input', $(this));
inputs.blur(function() {
var el = $(this);
el.siblings('div.feedback').remove();
var hasErrors = false;
$(enabledValidators).each(function() {
var result = validators[this](el);
if(result !== true) {
el.after('<div class="feedback feedback-error">' + result + '</div>');
hasErrors = true;
}
});
if(!hasErrors) {
el.filter(":visible").after('<div class="feedback feedback-ok"></div>');
}
});
});
}
});
})(jQuery);
我在这里所做的是将每个验证封装在它自己的函数中。它总是接收 de 元素,如果有效则返回 true,如果无效则返回带有错误的字符串。我还添加了一个enabledValidators,以便能够传递您想要运行的验证器(如果您愿意,您可以删除它并始终执行所有验证器,或者仅在没有传递任何内容的情况下使用所有验证器)。所以你可以这样调用它:
$(document).ready(function() {
$("form.new_user").live_validate(["required", "minlength"]);
}
关于javascript - 如何使我的验证更加惯用?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11247748/
我对 Clojure 和函数式编程有了大约一周的了解——我的所有背景都是 OOP。我想利用 Clojure 备受争议的易读性和固有逻辑,但现在我不知道我是否成功地做到了这一点,只是没有完全理解它,或者
场景: val col: IndexedSeq[Array[Char]] = for (i = 0 && arr(last.y)(west) == '.') { arr(last.y)(w
我正面临 AngularJS、服务和范围的“问题”。 这不是一个真正的问题(我找到了几种使其工作的方法),但我想知道我是否在做正确的事情,或者我正在做的事情是否会导致将来出现问题 我有一个保存一些全局
进行以下数据结构转换的“Rubyist”方法是什么: 我有 incoming = [ {:date => 20090501, :width => 2}, {:
如何在 go 中编写返回集合最小值的函数?我不只是在寻找解决方案(我知道我可以在遍历第一个元素时只初始化最小值,然后设置一个我初始化最小值的 bool 变量),而是一个惯用的解决方案。由于 go 没有
好的,我知道我应该对我的特定应用程序进行基准测试,等等,但是: -Xmx 的默认 JVM 设置、默认垃圾收集器等,对于大多数典型的 Java 程序来说是合理的默认设置,并且可能不适合惯用的 Scala
既然 shared_ptr 在 tr1 中,你认为 std::auto_ptr 的使用会发生什么?它们都有不同的用例,但 auto_ptr 的所有用例也都可以用 shared_ptr 解决。你会放弃
这个问题在这里已经有了答案: What are the differences between type() and isinstance()? (8 个回答) 关闭 9 年前。 我需要知道 Pyth
在指定和创建数字函数时,是否有关于何时返回 null 以及何时返回 NaN 的任何 C# 惯用准则,当两者似乎都是有效输出时。 导致这个问题的具体例子是我正在为 Enumerable 集合创建一个百分
这个问题在这里已经有了答案: Retrieving the top 100 numbers from one hundred million of numbers [duplicate] (12 个
我可以通过反射检索方法,以某种方式将其与目标对象结合起来,并将其作为看起来像 Scala 中的函数的东西返回(即您可以使用括号调用它)吗?参数列表是可变的。它不一定是“一流”函数(我已经更新了问题),
我是一名优秀的程序员,十分优秀!