回答如何检查 jQuery .data() 函数中是否存在值
(请不要反对将一堆数据值添加到表单对象的有效性,而不是我的决定)
这使
Object {v1: "value11", v2: "value2", v3: "value3", v4: "value4", v5: "value5"} fiddle.jshell.net:25
Uncaught TypeError: Object #<Object> has no method 'each'
注意:如果我将对象包装在 $(..) 中,它也不起作用
使用 $.each解决了jsfiddle 使用 $.each
$(function() {
$("form[name=update]").data("values", {"v1": "value11", "v2": "value2", "v3": "value3", "v4": "value4", "v5": "value5"});
$(".but").on("click",function(e) {
var $fData = $("form[name=update]").data("values");
var val = $(this).val();
console.log($fData);
$fData.each(function(n,i) {
console.log("!!!",n,i)
if (n[i]===val) {
alert("duplicate value");
return false;
}
})
e.preventDefault()
});
});
和
jsfiddle 使用 grep在任务中完全失败。
$(function() {
$("form[name=update]").data("values", {"v1": "value11", "v2": "value2", "v3": "value3", "v4": "value4", "v5": "value5"});
$(".but").on("click",function() {
var $fData = $("form[name=update]").data("values");
var val = $(this).val();
var idx = $.grep($fData, function(n,i) {
console.log("n",n); // why no console output for this???
return n[i]===val;
});
console.log(idx);
if (idx!=-1) {
alert("duplicate value")
}
});
});
问题:
- 为什么我不能
each
在返回的对象上运行 grep
我在做什么(之前只使用过一次 grep )- 为什么内部没有控制台输出
grep