下拉多选在日常的项目场景中用的不是特别多,但是每次用到,都很烦人。之前都是用的是bootstrap,但是项目中使用前端框架又不是它,导致又需要把bootstrap引入进去,而且有时候还会跟类似bootstrap前端框架冲突,导致样式出现问题。
这次就花点时间,结合网上的一些代码,自己做个一个只基于Jquery的轻量级下拉多选,不一定适合所有场景。
我们先来看效果图:
选择框使用的是input,点击弹出div下拉。
html代码
<!DOCTYPE html>
<html lang="ZH-ch">
<head>
<meta charset="UTF-8">
<title>drop</title>
<link rel="stylesheet" type="text/css" href="css/style.css">
</head>
<body>
<div style="margin: 100px;display: inline-block;width: 200px; ">
<input class="drop-header" placeholder="请输入" id="multiSelect2" />
<p style="height: 100px;"></p>
<input class="drop-header" placeholder="请输入" id="multiSelect" />
<p style="height: 50px;"></p>
<button style="width: 130px;" onclick="getval()" >获取值</button>
<button style="width: 130px;margin-top: 10px;" onclick="getTxtval()" >获取文本值</button>
</div>
<div style="margin: 100px;display: inline-block;width: 200px; ">
</div>
<!-- javascript -->
<script src="js/jquery-1.10.2.min.js"></script>
<script src="js/drop.js"></script>
</body>
<script>
function getTxtval(){
alert($("#multiSelect").val());
}
function getval(){
alert( $("#multiSelect").attr("tag") );
}
$(function () {
dropDwon({
id: 'multiSelect2',
myData: {
name4: {
val: '444'
},
name5: {
val: '555'
},
name6: {
val: '666'
},
name7: {
val: '777'
},
name8: {
val: '888'
},
},
callBack:function(){
console.log("init success");
}
})
dropDwon({
id: 'multiSelect',
myData: {
name1: {
val: '111',
selected: true
},
name2: {
val: '222',
selected: true
},
name3: {
val: '333',
selected: true
},
name4: {
val: '444'
},
name5: {
val: '555'
},
name6: {
val: '666'
},
name7: {
val: '777'
},
name8: {
val: '888'
},
},
callBack:function(){
console.log("init success");
}
})
})
</script>
</html>
CSS代码
* {
margin: 0;
padding: 0 ;
list-style: none;
box-sizing: border-box;
}
ul {
padding-left:0 !important;
}
.drop-header {
width: 100%;
padding: 5px 10px;
min-height: 32px;
border-radius: 3px;
background-color: #fff;
border: 1px solid #ccc ;
cursor: pointer;
padding-right: 28px;
background: url(