溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

JS實現(xiàn)點餐自動選擇框(案例分析)

發(fā)布時間:2020-10-05 13:39:45 來源:腳本之家 閱讀:199 作者:庚中 欄目:web開發(fā)

效果圖:

JS實現(xiàn)點餐自動選擇框(案例分析)

1. 目標(biāo)需求(一共兩個):

1.點擊上方全選/全不選選擇框,實現(xiàn)對應(yīng)功能
2.點擊下方選擇框,如果所有選擇框同時被選中,則上方全選框自動變成勾選狀態(tài),否則是非勾選狀態(tài)

2.思路分析:

1.實現(xiàn)上面選擇框全選全不選功能,添加上面的鼠標(biāo)點擊事件,讓下方所有選擇框跟上方一樣就行
2.下方選擇框在點擊時,使用開關(guān)思想來檢查是否是全部都選擇的狀態(tài)

3.js實現(xiàn)步驟:

上方全選/全不選選擇框,實現(xiàn)步驟

1.獲取元素

var chkAll=document.getElementById('checkAll');
 var chkList=document.getElementsByName('check');

2.實現(xiàn)上方選擇框全選/全不選功能

 chkAll.onclick=function ( ) {
   for(var i=0;i<chkList.length;i++){
    chkList[i].checked=this.checked;
    }
 }

3.下方選擇框點擊

開關(guān)思想:當(dāng)一個操作的結(jié)果只有兩種狀態(tài),就可以使用布爾類型來表示這兩種狀態(tài) isAllOk = true(全部選中)

1.提出假設(shè) isAllOk = true
2.驗證假設(shè)
3.根據(jù)驗證結(jié)果來實現(xiàn)需求

  

 //3.1遍歷下方按鈕,檢查下方按鈕的點擊事件
 for(var i=0;i<chkList.length;i++){
  chkList[i].onclick=function ( ) {
   var isAllChecked=true;//假設(shè)全部都是選中狀態(tài)
   for(var j=0;j<chkList.length;j++){
     if(chkList[j].checked==false){
      isAllChecked=false;
     }
    }
   //檢測完畢之后,根據(jù)開關(guān)的值來設(shè)置上方選擇框的狀態(tài)
   if(isAllChecked==true){
    chkAll.checked=true;
   }
   else {
    chkAll.checked=false;
   }
  }
  }

最后附上完整的代碼:

<!DOCTYPE html>
<html lang="en">
<head>
 <meta charset="UTF-8">
 <title>Title</title>
 <style>
  * {
   margin: 0;
   padding: 0;
  }
  table {
   border: 1px solid #c0c0c0;
   margin: 100px auto;
   /*margin兩個值代表上下,左右*/
   text-align: center;
   width: 500px;

   border-collapse: collapse;
   /*邊框合并,如果相鄰,則共用一個邊框*/
  }
  th{
   font:bold 15px "微軟雅黑";
   background-color: #09c;
   color: #fff;
   height: 24px;
  }
  td {
   border: 1px solid #d0d0d0;
   color: #404060;
   padding: 15px;
  }
 </style>
</head>
<body>
<table>
 <!--caption是表格的標(biāo)題-->
 <caption>點餐系統(tǒng)</caption>
 <thead>
 <tr>
  <th>
   <input type="checkbox" id="checkAll">全選/全不選
  </th>
  <th>菜名</th>
  <th>商家</th>
  <th>價格</th>
 </tr>
 </thead>
 <tbody>
 <tr>
  <td>
   <input type="checkbox" name="check"/>
  </td>
  <td>紅燒肉</td>
  <td>隆江豬腳飯</td>
  <td>¥200</td>
 </tr>
 <tr>
  <td>
   <input type="checkbox" name="check"/>
  </td>
  <td>香酥排骨</td>
  <td>隆江豬腳飯</td>
  <td>¥998</td>
 </tr>
 <tr>
  <td><input type="checkbox" name="check"/></td>
  <td>北京烤鴨</td>
  <td>隆江豬腳飯</td>
  <td>¥88</td>
 </tr>

 </tbody>
 <tfoot>
 <tr>
 </tr>
 </tfoot>
</table>
<script>
 //1.獲取界面對應(yīng)元素
 var chkAll=document.getElementById('checkAll');
 var chkList=document.getElementsByName('check');
 //2.實現(xiàn)上方選擇框全選/全不選功能
 chkAll.onclick=function ( ) {
   for(var i=0;i<chkList.length;i++){
    chkList[i].checked=this.checked;
    }
 }
 //3.實現(xiàn)下方選擇功能
 //3.1遍歷下方按鈕,檢查下方按鈕的點擊事件
 for(var i=0;i<chkList.length;i++){
  chkList[i].onclick=function ( ) {
   var isAllChecked=true;//假設(shè)全部都是選中狀態(tài)
   for(var j=0;j<chkList.length;j++){
     if(chkList[j].checked==false){
      isAllChecked=false;
     }
    }
   //檢測完畢之后,根據(jù)開關(guān)的值來設(shè)置上方選擇框的狀態(tài),下面也可以簡寫為 checkAll.checked = isAllChecked;
   if(isAllChecked==true){
    chkAll.checked=true;
   }
   else {
    chkAll.checked=false;
   }
  }
  }
</script>
</body>
</html>

總結(jié)

以上所述是小編給大家介紹的JS實現(xiàn)點餐自動選擇框,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對億速云網(wǎng)站的支持!
如果你覺得本文對你有幫助,歡迎轉(zhuǎn)載,煩請注明出處,謝謝!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI