在一个for循环
中当不满足之前的两个if
条件时,则弹出alert
提示框,由于做了遍历查询,所以alert
会根据数组数量多次弹出,请教这个应该如何做截断,让其判断后只弹出一次?
$(function(){
var jsons = [
{"id":"621234","info":"内容一"},
{"id":"62123456","info":"内容二"},
{"id":"624321","info":"内容三"},
]
function f(jsons,num) {
var num8 = num.substr(0,8);
var num6 = num.substr(0,6);
var result6 = '';
var result8 = '';
for(var i = 0,len = jsons.length; i < len;i++) {
var id = jsons[i].id;
if(id == num8) {
result8 = jsons[i].info.toString();
$("#card_info").fadeIn("500");
$("#close").fadeIn("500");
break;
}
if(id == num6) {
result6 = jsons[i].info.toString();
$("#card_info").fadeIn("500");
$("#close").fadeIn("500");
}
else{
alert("不符合条件");
}
}
return result8 ? result8 : result6;
}
$("#down").click(function(){
var user_info = $("#txt").val();
var table = document.getElementById("card_info");
table.innerHTML=(f(jsons, user_info));
})
});
目前这样写会根据json数据的条数,弹窗就会弹出三次。。。
雷雷
否则如果()
放在for循环外面,当result8和result6的值都为空的时候才alert。
为什么id==6时不break;?