jquery 的 each 方法中 return 的坑

jquery 的 each 方法中 return 的坑

Chapter 0

在项目中使用 jquery 的 each 方法时想在 each 的循环中返回一个布尔类型的值于是掉进一个坑中...

Chapter 1

最初的代码:

    这里的代码,虽然return 了,但是并未实际 return 值作为方法的返回值,而且还是继续往后执行。 在网上查询之后发现在 jquery 的 each 方法中如果 return true 相当于是 continue,而 return false 相当于是 break
 1 $(":checkbox[name='insurace-category']:checked").each(function (index,ele) {
 2         var _item = $(".gift_option_item_" + $(ele).val());
 3         if (_item && _item.length > 0) {
 4             var _premium = $.trim($(_item).find(".custom_inputbox").eq(0).val());
 5             var _selectElement = $(_item).find("select");
 6             if (_selectElement && _selectElement.length > 0 7                 var _amount = $.trim($(_selectElement).val());
 8                 if (!_amount) {
 9                     layer.msg("请选择保额!", () {
10                         $(_selectElement).focus();
11                     });
12                     return false;
13                 }
14             }
15             _premium) {
16                 layer.msg("请输入保费!",1)">() {
17                     $(_item).find(".custom_inputbox").eq(0).focus();
18                 });
19                 20 21         }
22     });
 

Chapter 2


我的解决方案如下:

修改后的代码:

 1    var _isInvalid =  2     $(":checkbox[name='insurace-category']:checked").each( 4          7              9                 10                     layer.msg("请选择保额!"                    $(_selectElement).focus();
12                     _isInvalid = true13                     15 16             17                 layer.msg("请输入保费!"18                 $(_item).find(".custom_inputbox").eq(019                 _isInvalid = 20                 22 23     });
24     if (_isInvalid) {
25         26     }

 

 
我这里借助了一个变量来辅助判断,当不满足条件时设置为 true,在循环外判断这个变量的值,如果变量的值是 true 则证明又不合法的值,如果变量的值为 false,则证明所需要判断的值都符合要求

Summary

  jquery each 方法中的 return 实际上是不会 return 啊,在 jquery each 方法中 return false,可以借助一个外部变量来辅助实现我们想要的功能。

相关文章

1.第一步 设置响应头 header('Access-Control-Allow...
$.inArray()方法介绍 $.inArray()函数用于在数组中搜索指定的...
jquery.serializejson.min.js的妙用 关于这个jquery.seriali...
JS 将form表单数据快速转化为object对象(json对象) jaymou...
jQuery插件之jquery.spinner数字智能增减插件 参考地址:http...