亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

jQuery+vue.js實現的多選下拉列表功能示例

2019-11-19 12:17:33
字體:
來源:轉載
供稿:網友

本文實例講述了jQuery+vue.js實現的多選下拉列表功能。分享給大家供大家參考,具體如下:

其實就是實現一個多選下拉列表,然后將選中的選項顯示到相應的位置;

因為主要是jQuery選中行為的實現,所以,樣式結構就不多說啦,直接貼代碼啦:

<!DOCTYPE html><html lang="en"><head>  <meta charset="UTF-8">  <meta name="viewport" content="width=device-width, initial-scale=1.0">  <meta http-equiv="X-UA-Compatible" content="ie=edge">  <script src="http://apps.bdimg.com/libs/jquery/2.1.4/jquery.min.js"></script>  <script src="http://apps.bdimg.com/libs/vue/1.0.14/vue.js"></script>  <title>多選下拉</title></head><body>    <div class="zj-div">     <div class="btn">全部級別</div>     <ul>      <li class='list' v-for="item in myData">{{item}}</li>     </ul>    </div></body></html>

li表單我這里利用了vue進行了簡單的的雙向數據綁定,哈哈哈  也是很偷懶啦

*{ padding: 0px; margin: 0px;}.zj-div{ position: relative; left: 50px; top: 50px;}.btn,li{ width: 200px; height: 50px; border: 1px solid #01bfda; border-radius: 15px; background: #000d16; color:white; line-height: 50px; text-align: center; font-size: 18px;}ul { display: none; width: 220px;}li { list-style: none;}li:hover{ cursor: pointer; background: #535a5c;}li[check="true"] { background: #01bfda;}

有一點需要注意的是,因為要實現多選,我想的是,選中的項與未選中的項通過不同的背景顏色進行區分;

所以就綁定了check屬性,當check='true'時,背景顏色不同;

下面就是重點啦,畫圈圈~~~

真的完全是利用自己的“強大”邏輯思維實現的,哈哈哈,也是很冗余啦~

因為不想直接引用組件,所以心血來潮就自己動手了,代碼中估計都能看出我的思考過程了吧~~~~

可以說是很費勁了,奈何因為方法不熟悉加上不太了解如何優化,用的最笨的方法-----根據最后要達到的目標,考慮會出現的情況,完成的最初的版本但也是最好理解的版本(雖然我都嫌棄有點長):

    new Vue({     el:".zj-div",     data:{      myData:["全部級別","一級","二級","三級"],     }    })   $(document).ready(function(){     var len = $('ul').children('li').length;     $('.btn').click(function(e) {      $('ul').slideToggle();      e.stopPropagation();    });                      //點擊.btn實現ul的收放    $(document).not($('.list')).click(function(e){       $('ul').slideUp();      })                    //.not方法就是除去當前這個元素                           //點擊頁面除了li的其他部分時,ul收起    for(let i = 0; i < len; i++){     var firstAll = $('ul').children().first();     var arr = [];                //為綁定.btn的值創建一個數組     $('li').eq(i).click(function(e){      e.stopPropagation();           //因為事件冒泡機制,一定要注意取消時間冒泡      if($(this).attr('check')!=="true"){        if($(this).text()=="全部級別"){    //如果當前點擊的是“全部級別”,則所有的li背景都改變           $(this).attr('check','true');           $(this).siblings().attr('check',"true");           // arr.push($(this).text());           $('.btn').text($(this).text());           arr = ["一級","二級","三級"];                           //此時.btn顯示"全部級別"        }else{         $(this).attr('check','true');    //如果當前點擊的li是其他的,則當前li背景改變          if(arr.includes($(this).text())){           $('.btn').text(arr);       //分情況討論此時.btn應該如何顯示          }else{               //注意結合arr           arr.push($(this).text());           $('.btn').text(arr);          }        }        if($(this).text()!=="全部級別"&&firstAll.next().attr('check')=='true'&&firstAll.next().next().attr('check')=='true'&&firstAll.next().next().next().attr('check')=='true'){         $('ul').children().first().attr('check','true');         $('.btn').text($('ul').children().first().text());        }                    //if判斷語句,我覺得肯定有其他的方法,我這個簡直太簡單粗暴了,可是我還沒想到...                            //這是我們應該考慮的一種情況,當其他幾項全選時,"全部級別"應該默認被選中      }else{        if($(this).text()=="全部級別"){     //同理,當當前元素被選中,再被點擊時要取消選中         $(this).attr('check','false');         $(this).siblings().attr('check',"false");         $('.btn').text($(this).text());    //注意此時,雖然.btn顯示為"全部級別"         arr = [];               //但實際上沒有任何元素被選中,所以arr實際為空        }else{         $(this).attr('check','false');         $('ul').children().first().attr('check','false');          for(var a = 0 ; a < arr.length; a++){           if(arr[a] == $(this).text()){            arr.splice(a,1);              //數組方法,刪除索引為a的一個元素            $('.btn').text(arr);            if(arr.length == 0){             //如果arr數據為空,那么.btn顯示"全部級別"             $('.btn').text(firstAll.text())            }           }          }        }      }    })   }  })

見解也就添加到注釋里面啦~~哈哈哈  反正也是自己看  吼吼吼~~~

好啦  效果圖:

慢慢的學習下來,我算是真的發現,好多東西,在真正動手前總覺得好像蠻簡單,可一旦入坑,就會陷入長久的困惑......

去做的過程中,總會發現新的問題~~~所以   我就記一下,免得下次又有同樣的需求,我又要重新思考  哈哈哈哈  也是很偷懶啦~~~畢竟  嗯  記憶力太差

That`s  all~~

Happy  Ending!!!

這里再給出一個完整示例代碼:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN""http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"><html xmlns="http://www.w3.org/1999/xhtml"><head><meta http-equiv="Content-Type" content="text/html; charset=utf-8" /><script src="http://apps.bdimg.com/libs/jquery/2.1.4/jquery.min.js"></script><script src="http://apps.bdimg.com/libs/vue/1.0.14/vue.js"></script><title>www.49028c.com 多選下拉</title><style>*{ padding: 0px; margin: 0px;}.zj-div{ position: relative; left: 50px; top: 50px;}.btn,li{ width: 200px; height: 50px; border: 1px solid #01bfda; border-radius: 15px; background: #000d16; color:white; line-height: 50px; text-align: center; font-size: 18px;}ul { display: none; width: 220px;}li { list-style: none;}li:hover{ cursor: pointer; background: #535a5c;}li[check="true"] { background: #01bfda;}</style></head><body>    <div class="zj-div">     <div class="btn">全部級別</div>     <ul>      <li class='list' v-for="item in myData">{{item}}</li>     </ul>    </div><script>    new Vue({     el:".zj-div",     data:{      myData:["全部級別","一級","二級","三級"],     }    })   $(document).ready(function(){     var len = $('ul').children('li').length;     $('.btn').click(function(e) {      $('ul').slideToggle();      e.stopPropagation();    });                      //點擊.btn實現ul的收放    $(document).not($('.list')).click(function(e){       $('ul').slideUp();      })                    //.not方法就是除去當前這個元素                           //點擊頁面除了li的其他部分時,ul收起    for(let i = 0; i < len; i++){     var firstAll = $('ul').children().first();     var arr = [];                //為綁定.btn的值創建一個數組     $('li').eq(i).click(function(e){      e.stopPropagation();           //因為事件冒泡機制,一定要注意取消時間冒泡      if($(this).attr('check')!=="true"){        if($(this).text()=="全部級別"){    //如果當前點擊的是“全部級別”,則所有的li背景都改變           $(this).attr('check','true');           $(this).siblings().attr('check',"true");           // arr.push($(this).text());           $('.btn').text($(this).text());           arr = ["一級","二級","三級"];                           //此時.btn顯示"全部級別"        }else{         $(this).attr('check','true');    //如果當前點擊的li是其他的,則當前li背景改變          if(arr.includes($(this).text())){           $('.btn').text(arr);       //分情況討論此時.btn應該如何顯示          }else{               //注意結合arr           arr.push($(this).text());           $('.btn').text(arr);          }        }        if($(this).text()!=="全部級別"&&firstAll.next().attr('check')=='true'&&firstAll.next().next().attr('check')=='true'&&firstAll.next().next().next().attr('check')=='true'){         $('ul').children().first().attr('check','true');         $('.btn').text($('ul').children().first().text());        }                    //if判斷語句,我覺得肯定有其他的方法,我這個簡直太簡單粗暴了,可是我還沒想到...                            //這是我們應該考慮的一種情況,當其他幾項全選時,"全部級別"應該默認被選中      }else{        if($(this).text()=="全部級別"){     //同理,當當前元素被選中,再被點擊時要取消選中         $(this).attr('check','false');         $(this).siblings().attr('check',"false");         $('.btn').text($(this).text());    //注意此時,雖然.btn顯示為"全部級別"         arr = [];               //但實際上沒有任何元素被選中,所以arr實際為空        }else{         $(this).attr('check','false');         $('ul').children().first().attr('check','false');          for(var a = 0 ; a < arr.length; a++){           if(arr[a] == $(this).text()){            arr.splice(a,1);              //數組方法,刪除索引為a的一個元素            $('.btn').text(arr);            if(arr.length == 0){             //如果arr數據為空,那么.btn顯示"全部級別"             $('.btn').text(firstAll.text())            }           }          }        }      }    })   }  })</script></body></html>

感興趣的朋友可以使用在線HTML/CSS/JavaScript代碼運行工具http://tools.VeVB.COm/code/HtmlJsRun運行上述代碼,測試運行效果。

更多關于jQuery相關內容感興趣的讀者可查看本站專題:《jQuery常見事件用法與技巧總結》、《jQuery常用插件及用法總結》、《jQuery操作json數據技巧匯總》、《jQuery擴展技巧總結》、《jQuery常見經典特效匯總》及《jquery選擇器用法總結

希望本文所述對大家jQuery程序設計有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
成人免费网站在线| 亚洲成人中文字幕| 欧美成人在线影院| 国产精品第一页在线| 国产精品欧美一区二区三区奶水| 国产精品一区二区三区在线播放| 中文字幕欧美精品日韩中文字幕| 91在线视频一区| 国产亚洲人成网站在线观看| 欧美色xxxx| 欧美第一黄网免费网站| 欧美多人乱p欧美4p久久| 亚洲黄色有码视频| 日韩欧美在线播放| 欧美精品一区二区免费| 亚洲成人aaa| 日本精品在线视频| 色噜噜国产精品视频一区二区| 久久国内精品一国内精品| 26uuu亚洲伊人春色| 欧美三级免费观看| 国内精品久久久久久久| 日韩美女视频中文字幕| 欧美精品videosex牲欧美| 精品国产精品自拍| 热久久美女精品天天吊色| 久热精品视频在线观看一区| 日韩电影免费观看在线| 久久九九全国免费精品观看| 国产精品91在线观看| 97在线免费视频| 欧美在线观看www| 亚洲第一精品自拍| 92裸体在线视频网站| 午夜精品久久久久久久白皮肤| 一本一本久久a久久精品综合小说| 久久久国产精品视频| 亚洲已满18点击进入在线看片| 欧美视频中文字幕在线| 亚洲午夜精品久久久久久性色| 日韩欧美一区视频| 777午夜精品福利在线观看| 欧美在线不卡区| 国产精品老牛影院在线观看| 影音先锋欧美精品| 欧美激情一区二区三级高清视频| 精品国产区一区二区三区在线观看| 在线观看久久久久久| 国产精品久久久久久中文字| 亚洲奶大毛多的老太婆| 国产男女猛烈无遮挡91| 国产精品一区av| 亚洲激情免费观看| 国产精品久久久久久久久久久久久| 国产91精品高潮白浆喷水| 国产婷婷成人久久av免费高清| 国产一区二区三区在线观看视频| 日日摸夜夜添一区| 色视频www在线播放国产成人| 国产网站欧美日韩免费精品在线观看| 国产一区二区三区在线播放免费观看| 国产精品99久久久久久白浆小说| 欧美亚洲国产另类| 久久久久久久成人| 国产一区欧美二区三区| 亚洲黄在线观看| 亚洲一区二区少妇| 国产一区二区视频在线观看| 国产性色av一区二区| 91av在线精品| 亚洲电影免费观看| 国产午夜精品一区理论片飘花| 美女视频黄免费的亚洲男人天堂| 在线看日韩av| 欧美激情中文字幕乱码免费| 国产精品丝袜一区二区三区| 欧美最顶级丰满的aⅴ艳星| 97高清免费视频| 国产视频丨精品|在线观看| 高清一区二区三区四区五区| 亚洲国产欧美一区二区三区同亚洲| 成人黄色激情网| 国产日韩换脸av一区在线观看| 2023亚洲男人天堂| 欧美激情在线视频二区| 亚洲精品福利在线观看| 成人动漫网站在线观看| 91精品国产高清久久久久久91| 亚洲高清久久久久久| 91精品久久久久久久久久久| 日韩av网站导航| 一个色综合导航| 国产成人97精品免费看片| 欧美国产一区二区三区| 国产视频精品久久久| 98午夜经典影视| 亚洲免费中文字幕| 国产精品美女免费视频| 久久国产精品久久久久久久久久| 国产精品福利网站| 午夜精品免费视频| 欧美性猛交xxxx| 81精品国产乱码久久久久久| 中文字幕综合一区| 精品视频中文字幕| 亚洲电影免费观看高清| 亚洲 日韩 国产第一| 97超碰色婷婷| 青青草原成人在线视频| 91免费看片网站| 久久国产精品久久久久久| 一区二区三区高清国产| 久久躁狠狠躁夜夜爽| 久久99久久久久久久噜噜| 亚洲二区中文字幕| 色樱桃影院亚洲精品影院| 日韩精品在线观看一区二区| 国产一区二区成人| 日韩精品欧美激情| 4438全国成人免费| 久久久精品一区二区三区| 日韩精品中文字幕在线观看| 成人激情黄色网| 久久久久一本一区二区青青蜜月| 91精品免费视频| 亚洲男人天堂2023| 欧美精品video| 456亚洲影院| 在线午夜精品自拍| 欧美一区二区三区图| 免费91麻豆精品国产自产在线观看| 欧美日韩国产在线播放| 中文字幕不卡av| 国产精品久久国产精品99gif| 欧美激情高清视频| 成人黄在线观看| 欧美成人中文字幕| 欧美激情影音先锋| 国产精品99久久久久久www| 中文字幕免费精品一区高清| 亚洲精品国产综合区久久久久久久| 中文字幕亚洲自拍| 亚洲成人黄色在线观看| 色综合久久中文字幕综合网小说| 中文字幕日韩免费视频| 久久婷婷国产麻豆91天堂| 国产a级全部精品| 影音先锋日韩有码| 久久国产精品影视| 欧美精品www| 日韩精品在线观看一区二区| 国产日产久久高清欧美一区| 亚洲国产精品高清久久久| 国产欧美日韩免费| 欧美自拍视频在线观看| 91精品中文在线| 欧美最猛性xxxxx免费| 亚洲人成五月天| 久久av红桃一区二区小说| 亚洲视频在线观看网站| 欧美日韩在线第一页| 国语对白做受69| 国产剧情日韩欧美| 日韩综合视频在线观看|