成人精品一区二区三区中文字幕-成人精品一区二区三区-成人精品一级毛片-成人精品亚洲-日本在线视频一区二区-日本在线视频免费

導航首頁 ? 技術教程 ? 用自定義圖片代替原生checkbox實現全選,刪除以及提交的方法
全站頭部文字 我要出現在這里
用自定義圖片代替原生checkbox實現全選,刪除以及提交的方法 675 2024-02-15   

UI妹子覺得原生的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="http://www.gimoo.net/t/1811/images/check.png" style="display:none;"> 

當然,也可以用CSSSprites精靈圖。

注:本文是使用了jQuery來用自定義圖片代替原生checkbox復選框實現全選,刪除,表單提交。

換成原生JavaScript也不難。

以上就是小編為大家帶來的用自定義圖片代替原生checkbox實現全選,刪除以及提交的方法全部內容了,希望大家多多支持綠夏網~



主站蜘蛛池模板: 二年级上册期末真题卷| 老板娘2无间潜行| h罩杯美女| 致命玩笑| 好妻子剧情简介| 西海情歌歌词全文| 美女洗澡直播| 七年级下册英语第二单元作文| 女女调教| 丰崎爱生| 欧卡2mod| 风间由美风间ゆみav| 蒂塔万提斯全集免费观看| 六年级上册脱式计算题100道| 韩国电影解禁男女| 转转二手手机| 《爱与野蛮》电影| 天国车站在线观看| 色在线播放| 电影《追求》| 一个蛋挞的热量| 红装电影在线观看免费版电视剧全集| 一线钟情 电视剧| 一元二次方程实际问题| 美女又黄又免费的视频| 手机图标大全| 真命小和尚电视剧| 婚前协议电视剧演员表| 仓皇一夜| 韩宇辰| 金允石| 庆余年2演员表全部员表| 伤残等级1-10标准图| 恶作剧之吻3| 八年级上册英语课文| 莱克茜·贝尔| 播放凯登克罗斯演的全部影片| 87电影| 爱的替身| 实力主义教室第三季| kiss the rain钢琴谱|

!!!站長長期在線接!!!

網站、小程序:定制開發/二次開發/仿制開發等

各種疑難雜癥解決/定制接口/定制采集等

站長微信:lxwl520520

站長QQ:1737366103