Flask接口签名sign原理与实例代码浅析
499
2023-01-30
vue组件实现可搜索下拉框扩展
本文实例为大家分享了vue组件实现可搜索下拉框的具体代码,供大家参考,具体内容如下
一、效果
二、代码
dropdown-ext.vue
:placeholder="placeholder" />
:key="index" :title="item.name">
:style="itemTextStyle">{{item.name}}
:class="item.statusClass">{{item.statusText}}
:class="item.statusClass">{{item.statusText}}
:class="item.statusClass">
export default {
data(){
return {
_datalist:this.itemlist.concat(),
datalist:this.itemlist.concat(),
length:this.itemlist.length
}
},
props:{
'show':{//用于外部控制组件的显示/隐藏
type:Boolean,
default:true
},
'itemlist':Array,
'placeholder':String,
'nodatatext':String,
'themestyle':{
type:String,
default:'default-theme'
},
'item-text-style':{
type:Object,
default:function(){
return {
width:'80%'
}
}
},
'add-icon':{
type:Boolean,
default:true
},
'icon-class':{
type:String,
default:''
},
'has-status':{
type:Boolean,
default:false
},
'status-icohttp://n-type':{
type:String,
default:'text'//text or icon
},
'max-h':{
type:Number,
default:$(window).height()-400
}
},
directives:{
'show-extend':function(el,binding,vnode){//bind和 update钩子
let value = binding.value,searchInput = null;
if(value){
el.style.display='block';
}else{//隐藏后,恢复初始状态
el.style.display='none';
searchInput = el.querySelector(".search-text");
searchInput.value = '';
//还原渲染数据
vnode.context.datalist = vnode.context.itemlist;
}
}
},
methods:{
appClick:function(data,event){
this.$emit('item-click',data,event);
},
search:function(e){
let vm = this,searchvalue = e.currentTarget.value;
vm.datalist = vm.$data._datalist.filter(
function(item,index,arr){
return item.name.indexOf(searchvalue) != -1;
});
},
statusIconClass:function(status){
let statusClass = '';
return statusClass;
}
},
mounted:function(){
}
}
.text-overflow__style {
overflow: hidden;
white-space: nowrap;
text-overflow: ellipsis;
}
.vue-dropdown-ext {
.search-module {
position: relative;
.search-text {
width: 100%;
height: 30px;
padding-right: 2em;
padding-left:0.5em;
box-shadow: none;
border: 1px solid #ccc;
background: #fff;
&:focus {
border-color: #2198f2;
}
}
.search-icon {
position: absolute;
top: 24%;
right: 0.5em;
color: #aaa;
}
}
.list-module {
overflow: auto;
li {
position: relative;
margin-top: 0.5em;
padding: 0.5em;
border: 1px solid #ccc;
white-space: nowrap;
&>span {
display: inline-block;
vertical-align: middle;
}
}
}
.tip__nodata {
font-size: 12px;
margin-top: 1em;
}
&.default-theme {
.list-module li {
&:hover {
cursor: pointer;
border-color: #00a0e9;
}
&.active {
border-color: #00a0e9;
color: #00a0e9;
}
}
}
}
版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。
发表评论
暂时没有评论,来抢沙发吧~