要代替原生的checkbox。 那么要实现原生checkbox能干的事。我们主要实现这几点就可以了。
1.点击列表中的勾选图片。图片会变换成相反的。
2.如果当前是全选状态,不勾选列表中的某一项,全选处的图片变成未勾选的状态。
如果点击了某一项使列表成了全选的状态, 全选处的图片变成勾选状态。
3.全选功能
4.点击删除,能删除全部的勾选的图片。
1.准备工作:因为要大量用到两个图片的切换,我们单独定义出来:
var uncheckUrl = "images/uncheck.png"; var checkUrl = "images/check.png";2.点击列表中的勾选图片,图片变成相反的,并且可能引发 全选图片的变化。
//点击复选框图片 $("#ul").on("click", "li img", function(event) {var imgDom = $(this);if(imgDom.attr("src")==checkUrl){ $("#SelectAllImg").attr("src",uncheckUrl); imgDom.attr("src",uncheckUrl); }else{ imgDom.attr("src",checkUrl);//上面部分是变换图片自身,下面部分是检测是否要变换全选图片。 //通过比较图片总数量与选中图片数量来决定。 var imgLength = $("#ul li img").length; var checkLength = 0;for (var i = 0; i <= imgLength; i++) { if($("#ul li img").eq(i).attr("src") == checkUrl){ checkLength ++; } }if(imgLength == checkLength){ $("#SelectAllImg").attr("src",checkUrl); } } });3.全选功能。改变全选图标的同时,改变所有图标,跟全选图标保持一致。
//全选中的图标 $("#SelectAllImg").click(function() { if($(this).attr("src")== checkUrl){$(this).attr("src",uncheckUrl); $("#ul li img").attr("src",uncheckUrl); }else{ $(this).attr("src",checkUrl); $("#ul li img").attr("src",checkUrl); } });4.删除功能。 点删除按钮,删除勾选的图片所在的行。
//删除选中的数据 $("#del").click(function() {var imgLength = $("#ul li img").length; var checkDom = "";for (var i = imgLength - 1; i >= 0; i--) { checkDom = $("#ul li img").eq(i); if(checkDom.attr("src") == checkUrl){ checkDom.parent().remove(); }; };});5.最后我们要提交表单的时候,如何处理呢? 我们是用ajax提交还是直接表单submit提交呢?
var deviceIdArr = []; $("#ul li img").each(function() { if($(this).attr("src") == checkUrl){ deviceid = trim($(this).parent().text()); deviceIdArr.push(deviceid); } });5.2表单提交思路。
<img src="images/check.png" style="display:none;">当然,也可以用CSSSprites精灵图。