国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

用jQuery實現可輸入多選下拉組合框實例代碼

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

  【寫在前面的話】網站上很多用各種插件,比如依賴bootstrap的bootstrap-select插件等。雖然這些框架可以實現很多功能,但因為在實際項目中,可能只會用到其中的某個功能,若是一概引入,會導致整個js加載過于笨重。比如前面提到的bootstrap-select插件,在不壓縮的情況下,達到300多k。因此,為了實現一個可填寫的下拉框有點得不償失。

  基于這種原因,于是私下用jquery寫了一個比較簡單的多選下拉可填寫組合框。  

 container{   margin: 20px auto;   padding:0 15px;   width: 50%;    height:300px;   box-sizing: border-box;    }  .text-container{   display: inline-block;   float:left;   width: 15%;   height: 32px;   line-height: 32px;   box-sizing: border-box;  }  .selectContainer{   width: 70%;   height:200px;   float:left;   position: relative;   padding:0;   margin:0;   box-sizing: border-box;  }  .selectedContent{   width:85%;   height: 25px;   float:left;     }  .dropDown-toggle{   width:14%;   height:31px;   line-height: 31px;   text-align: center;   border: 1px solid silver;   border-left:none;   float:left;   padding:0;   margin:0;   box-sizing: border-box;   cursor: pointer;  }  .dropDown-menu{   margin:0;   padding:0 15px 10px;   width:100%;   border:1px solid silver;   border-top: none;   box-sizing: border-box;   list-style: none;   position: absolute;   top:31px;   right:0;  }  .items{   margin-top:8px;   padding: 2px;   cursor: pointer;  }  .items:hover{   background: #ddd;  }  .isSelectedText{   display: inline-block;   width:90%;  }  .dsn{   display: none;  }
<div class="container"> <span class="text-container">最愛的水果</span> <div class="multipleSelect selectContainer">  <input type="text" class="selectedContent">  <div class="dropDown-toggle">選擇</div>  <ul class="dropDown-menu dsn">   <li class="items">    <span class="isSelectedText">蘋果</span>    <span class="isSelected"><input type="checkbox"></span>   </li>   <li class="items">         <span class="isSelectedText">梨</span>    <span class="isSelected"><input type="checkbox"></span>   </li>   <li class="items">    <span class="isSelectedText">橘子</span>    <span class="isSelected"><input type="checkbox"></span>   </li>   <li style="text-align: right">    <button type="button" class="confirmSelect">確定</button>   </li>  </ul> </div></div>
$('.isSelected input[type=checkbox]').on('click', function(){   var selectedItems = $(this).parents('.dropDown-menu').prevAll('.selectedContent').val().split(' ');   var thisItem = $(this).parent().prev().text();   var isExisted = 0;   var isChecked = $(this).is(':checked');   if(isChecked){    selectedItems.map(function(item, index){     if(item === thisItem){      isExisted++     }    });    if(!isExisted){     selectedItems.push(thisItem)    }   }   else{    selectedItems.map(function(item, index){     if(item === thisItem){      selectedItems.splice(index, 1);     }    });   }   $(this).parents('.dropDown-menu').prevAll('.selectedContent').val(selectedItems.join(' '));  })  $('.confirmSelect').on('click', function(){   $(this).parents('.dropDown-menu').addClass('dsn');  })  $('.dropDown-toggle').on('click', function(){   $(this).next().toggleClass('dsn')  });

  由于本組件中使用了數組的map方法,可能此方法在ie中不能兼容。由于鄙人電腦ie無法打開,用360瀏覽器測試后同樣可是正常使用。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 永济市| 香港| 虎林市| 嵊泗县| 青铜峡市| 泊头市| 莱西市| 罗田县| 江都市| 宁夏| 米脂县| 吉隆县| 姜堰市| 花垣县| 和政县| 蒙阴县| 东海县| 孟州市| 麻江县| 石家庄市| 永平县| 札达县| 武冈市| 鄢陵县| 湘阴县| 兴隆县| 温宿县| 都匀市| 定安县| 大港区| 康保县| 沁水县| 霸州市| 贡嘎县| 大悟县| 华阴市| 青州市| 衡山县| 叙永县| 阜康市| 乐陵市|