用自定义图片代替原生checkbox实现全选,删除以及提交的方法


Posted in Javascript onOctober 18, 2016

UI妹子觉得原生的checkbox复选框太丑,非要用图片来代替,那就依她。做出来的效果类似这样:

用自定义图片代替原生checkbox实现全选,删除以及提交的方法

要代替原生的checkbox。 那么要实现原生checkbox能干的事。我们主要实现这几点就可以了。

1.点击列表中的勾选图片。图片会变换成相反的。

2.如果当前是全选状态,不勾选列表中的某一项,全选处的图片变成未勾选的状态。

如果点击了某一项使列表成了全选的状态, 全选处的图片变成勾选状态。

3.全选功能

4.点击删除,能删除全部的勾选的图片。

1.准备工作:因为要大量用到两个图片的切换,我们单独定义出来:

var uncheckUrl = 'images/uncheck.png'; 
var checkUrl = 'images/check.png';

2.点击列表中的勾选图片,图片变成相反的,并且可能引发 全选图片的变化。

我们用on事件,因为列表中的信息是动态添加进去的。

//点击复选框图片 
$("#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.删除功能。 点删除按钮,删除勾选的图片所在的行。 

注意:里面的循环是倒序循环。 这样处理的原因是:如果顺序循环,那么删除了前面的行,真实的imglength就变小了,所有后面的节点的索引值都发生了变化,往前移了, 而我们 eq(i)来删除序号为i的节点,就删除不到了。

//删除选中的数据 
$("#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提交呢?
这里提供两种方案的思路。

5.1 ajax思路,本人比较喜欢用ajax提交。

类似这样,deviceIdArr就获取到了选中的框的 内容。 你要获取该列的id,也类似。

var deviceIdArr = []; 
$('#ul li img').each(function() { 
  if($(this).attr('src') == checkUrl){ 
    deviceid = trim($(this).parent().text()); 
    deviceIdArr.push(deviceid); 
  } 
});

5.2表单提交思路。

在每一个图片checkbox的旁边,放上一个隐藏的真实checkbox。这样用户就看不到。

每一次对选中图片进行修改的时候,都对应地修改相应隐藏checkbox的选中状态,

最后提交的时候直接提交隐藏checkbox的状态就好。

调试的时候可以让那些隐藏的checkbox显现出来,方便我们直观看到checkbox与图片的对应状态是否准确。

6.一点优化意见。为了避免 第一次 点击 图片时 切换图片的延迟感,可 预加载 选中状态的图片 和 未选中状态的图片。 

比如我们这个默认状态下会显示未选中的图标, 而选中状态的图标是没有显示的。 如果等点击的时候再来加载,就会有延迟感。

解决办法,在页面底部加上这一句:

<img src="images/check.png" style="display:none;">

当然,也可以用CSSSprites精灵图。

注:本文是使用了jQuery来用自定义图片代替原生checkbox复选框实现全选,删除,表单提交。

换成原生JavaScript也不难。

以上就是小编为大家带来的用自定义图片代替原生checkbox实现全选,删除以及提交的方法全部内容了,希望大家多多支持三水点靠木~

Javascript 相关文章推荐
jQuery extend 的简单实例
Sep 18 Javascript
一个很有趣3D球状标签云兼容IE8
Aug 22 Javascript
Javascript数组与字典用法分析
Dec 13 Javascript
jQuery实现长按按钮触发事件的方法
Feb 02 Javascript
js实现从中间开始往上下展开网页窗口的方法
Mar 02 Javascript
Node.js插件安装图文教程
May 06 Javascript
AngularJS基础 ng-mouseleave 指令详解
Aug 02 Javascript
vue开发心得和技巧分享
Oct 27 Javascript
关于redux-saga中take使用方法详解
Feb 27 Javascript
vue获取当前激活路由的方法
Mar 17 Javascript
JS获取url参数,JS发送json格式的POST请求方法
Mar 29 Javascript
vue 使用rules对表单字段进行校验的步骤
Dec 25 Vue.js
jquery中用jsonp实现搜索框功能
Oct 18 #Javascript
JavaScript排序算法动画演示效果的实现方法
Oct 18 #Javascript
浅谈js的异步执行
Oct 18 #Javascript
Jquery AJAX POST与GET之间的区别详细介绍
Oct 17 #Javascript
微信小程序 教程之模块化
Oct 17 #Javascript
微信小程序 教程之注册页面
Oct 17 #Javascript
微信小程序 教程之注册程序
Oct 17 #Javascript
You might like
如何对PHP程序中的常见漏洞进行攻击
2006/10/09 PHP
PHP的中问验证码
2006/11/25 PHP
PHP Memcached应用实现代码
2010/02/08 PHP
php 过滤器实现代码
2010/08/09 PHP
PHP临时文件的安全性分析
2014/07/04 PHP
CentOS系统中PHP安装扩展的方式汇总
2017/04/09 PHP
PHP实现redis限制单ip、单用户的访问次数功能示例
2018/06/16 PHP
php中的钩子理解及应用实例分析
2019/08/30 PHP
理解Javascript_02_理解undefined和null
2010/10/11 Javascript
利用JS延迟加载百度分享代码,提高网页速度
2013/07/01 Javascript
jQuery实现带幻灯的tab滑动切换风格菜单代码
2015/08/27 Javascript
学习使用jquery iScroll.js移动端滚动条插件
2020/03/24 Javascript
基于原生JS实现图片裁剪
2016/08/01 Javascript
JavaScript异步上传图片文件的实例代码
2017/07/04 Javascript
Javascript中从学习bind到实现bind的过程
2018/01/05 Javascript
详解小程序开发经验:多页面数据同步
2019/05/18 Javascript
jQuery+PHP+Ajax实现动态数字统计展示功能
2019/12/25 jQuery
node.js中module模块的功能理解与用法实例分析
2020/02/14 Javascript
如何利用nodejs实现命令行游戏
2020/11/24 NodeJs
[01:37]PWL S2开团时刻DAY1&2——这符有毒
2020/11/20 DOTA
在dataframe两列日期相减并且得到具体的月数实例
2018/07/03 Python
用python打印菱形的实操方法和代码
2019/06/25 Python
详解pandas DataFrame的查询方法(loc,iloc,at,iat,ix的用法和区别)
2019/08/02 Python
python elasticsearch从创建索引到写入数据的全过程
2019/08/04 Python
python3 selenium自动化 frame表单嵌套的切换方法
2019/08/23 Python
Python Gitlab Api 使用方法
2019/08/28 Python
python剪切视频与合并视频的实现
2020/03/03 Python
Keras使用ImageNet上预训练的模型方式
2020/05/23 Python
使用canvas压缩图片大小的方法示例
2019/08/02 HTML / CSS
Forever 21美国官网:美国标志性快时尚品牌
2017/02/20 全球购物
建筑公司员工自我鉴定
2014/04/08 职场文书
医生爱岗敬业演讲稿
2014/08/26 职场文书
党员学习党的群众路线思想汇报(5篇)
2014/09/10 职场文书
企业务虚会发言材料
2014/10/20 职场文书
运动会开幕式主持词
2015/07/01 职场文书
浅谈JS的原型和原型链
2021/06/04 Javascript