问题描述
1.最近用layui做后台界面,遇到layui跟ajax数据动态加载的checkbox,偶尔不能正常勾选,取消
2.有分页时,最后一页数据过少会导致其他页下方数据无法选中
3.页面没加载完或暴力测试时也会不能选中
利用layui更新渲染方法和网上的一些方法去解决后极大的减少了无法选中的情况,但是暴力测试时偶尔还会出现,实在不知道什么原因,所以就用了一个折中的方法——自己写一个复选框
<!--原有layui复选框-->
<td>
<div class="layui-unselect layui-form-checkbox" lay-skin="primary" data-id='2'><i class="layui-icon"></i></div>
</td>
<!--替换为自己写的-->
<td>
<div a="off" class="checkBox" v-bind:data-id='x.Id' v-on:click="checkBox(i)">
<div></div>
</div>
</td>
自己写的同样支持vue绑定事件,并且支持单个选中、取消,全选和取消
//单个的选中取消
checkBox:function(n){ var checkbox = $('tbody tr').eq(n).find('.checkBox'); if (checkbox.attr("a") == "off") { checkbox.children("div").css({ "display" : "block" }); checkbox.attr("a","on"); }else { checkbox.children("div").css({ "display" : "none" }); checkbox.attr("a","off"); } }
//全选取消
checkBoxAll:function(){ var obj = $('thead').find('.checkBox'); if ($(obj).attr("a") == "off") { $('.checkBox div').css({"display" : "block"}); $('.checkBox').attr("a","on"); }else { $('.checkBox div').css({"display" : "none"}); $('.checkBox').attr("a","off"); } }
全选或者选中其中几个,获取对应id,删除或进行其他操作
function getId() {
var obj = $("tbody .checkBox");
var arr='';
obj.each(function(index, el) {
if(obj.eq(index).attr("a") == "on"){
arr += obj.eq(index).attr('data-id')+ ','
}
});
return arr;
}
在使用layui构建后台界面时,遇到动态加载的checkbox选中问题,特别是涉及ajax数据、分页和页面加载速度时。通过layui的更新渲染方法和其他网络解决方案虽有改善,但在暴力测试下仍有偶尔无法选中的情况。为解决此问题,选择自定义复选框组件,该组件支持Vue绑定事件,能实现单选、全选、取消选中,并能获取选中项的id用于后续操作。

2640

被折叠的 条评论
为什么被折叠?



