(上加入一些數據值到表單對象,而不是我的決定的合法性,請不downvotes)接聽How to check if value exist in jQuery .data() function瞭解數據對象,每個和grep
我創建了一個jsfiddle using each
這給
Object {v1: "value11", v2: "value2", v3: "value3", v4: "value4", v5: "value5"} fiddle.jshell.net:25
Uncaught TypeError: Object #<Object> has no method 'each'
注:如果我在包裹$對象(..)它不工作,要麼
解決使用$。每個jsfiddle using $.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 using 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
我認爲grep只適用於數字索引數組,而不是對象。 –