由于业务需要,需要一个可输入也可下拉的组件,看了iview没有现成的组件用,就自己封装了个小组件~~

组件input-select.vue代码:

<template>
<div class="input-container">
<!-- 显示的输入框,用v-model绑定数据,并且绑定focus事件 -->
<Input class="input-number" v-model="inputData" @on-focus="_showInputNumber" />
<!-- -->
<div class="input-dropdown-wrap">
<Dropdown trigger="custom" :visible="visibNormal" class="input-dropdown">
<Dropdown-menu slot="list">
<div class="dropdown-list">
<Row class="item" v-fot="item of arrayList" :value="item.code" :key="item.code" @click.native="_inputNumChange(item.code)">{{item.text}}</Row>
</div>
</Dropdown-menu>
</Dropdown>
</div>
</div>
</template> <script>
/**
* 输入下拉框
* @author mino
* @version 1.0.0
* @description 可输入,也可展开下拉框进行选择
*/
export default {
data() {
return {
inputData: '1', //输入框的默认值
visibNormal: false //下拉显示控制
}
},
props: {
arrayList: { //下拉列表的数据
type: Array,
default: []
}
},
watch: {
inputData(newVal) {
this.$emit('getInputNum', newVal);
}
},
methods: {
//展示下拉选项
_showInputNumber(e) {
let _this = this;
if(this.visibNormal) return; this.visibNormal = true;
//给输入框元素加入阻止冒泡事件
e.target.addEventListener('click', (e) => {
e.stopPropagation();
});
document.addEventListener('click', _this._hideNormal);
},
//下拉框列表的点击事件
_inputNumChange(data) {
this.$emit('getInputNum', data);
},
//隐藏下拉框
_hideNormal() {
let curTarget = event.target;
if(curTarget.nodeName === 'SPAN' && curTarget.classList.contains('switch)) {
return;
} this.visibNormal = false;
document.removeEventListener('click', this._hideNormal);
}
}
}
</script> <style scoped lang="less">
.input-container {
/deep/ .input-dropdown-wrap {
height: 0 !important;
overflow: hidden;
}
.dropdown-list {
height: 1.3rem;
overflow: auto;
border-bottom: .01rem solid #E4E4E4;
.item {
line-height: .25rem;
padding-left: .15rem;
&:hover {
background: grey;
}
}
}
.input-number {
width: 2.2rem;
}
.input-dropdown {
width: 2.2rem;
/deep/ .ivu-select-dropdown {
margin-top: -.2rem;
}
}
}
</style>

调用该组件的组件index.vue代码块为:

<template>
<div class="main-container">
<inputSelect :arrayList="_arrayList" @getInputNum="_getInputNum" />
</div>
</template> <script>
/**
* 输入下拉组件引用主入口
* @author mino
* @version 1.0.0
* @description 引用输入下拉组件
*/
import inputSelect from './input-select';
export default {
data() {
return {
_arrayList: [
{
code: '1',
text: '111'
},
{
code: '3',
text: '333'
},
{
code: '5',
text: '555'
}
],
inputSelectData: '' //接收子组件的值
}
},
components: {
inputSelect
},
methods: {
//获取子组件的值
_getInputNum(data) {
console.log('this is data of input-select: ', data);
this.inputSelectData = data;
}
}
}
</script>

Vue 可输入可下拉组件的封装的更多相关文章

  1. js实现可输入的下拉框

    <HTML> <HEAD> <META http-equiv='Content-Type' content='text/html; charset=gb2312'> ...

  2. amazeui学习笔记--js插件(UI增强4)--下拉组件Dropdown

    amazeui学习笔记--js插件(UI增强4)--下拉组件Dropdown 一.总结 1.am-dropdown(及其孩子):控制下拉列表的样式 2.data-am-dropdown(及其孩子):控 ...

  3. vue 表格中的下拉框单选、多选处理

    最近在用vue做前后端分离,需要在表格中用到下拉框,由于需求变动,从最开始的单选变为多选,折腾了许久,记录一下,供后人铺路 vue 中的表格下拉框单选 collectionsColnumOptions ...

  4. Vue自定义指令实现下拉加载:v-loadmore

    和methods平级: directives: { loadmore: {//自定义指令: 下拉加载 bind(el, binding) {    var p = 0;    var t = 0;  ...

  5. vue的jsonp百度下拉菜单

    通过vue的jsonp实现百度下拉菜单的请求,vue的版本是2.9.2 <!DOCTYPE html> <html lang="en"> <head& ...

  6. Html5下拉控件同时支持文本输入和下拉代码

    有时候,下拉框不能满足我们的业务需求,还需要同时支持用户输入内容,默认的select标签是不支持用户输入的,下面我说一下原生的select如何支持用户输入,代码如下: <!DOCTYPE htm ...

  7. vue实现百度搜索下拉提示功能

    这段代码用到vuejs和vue-resouece.实现对接智能提示接口,并通过上下键选择提示项,按enter进行搜索 <!DOCTYPE html> <html lang=" ...

  8. vue 获取数据联动下拉框select ,并解决报Duplicate value found in v-for="...": "". Use track-by="$index" 错误

    公司项目中遇到一个问题,联动下拉框,并且数据是使用vue-resource从后台获取的,格式不利于输出联动下拉框,联动下拉框是第一个下拉框输出一个数组里每一项json的一个text值,从而第二下拉框输 ...

  9. jquery模拟可输入的下拉框

    //页面html <div id="select" class="select" > <ul> <c:forEach items= ...

随机推荐

  1. Ubuntu 16.04 环境下配置apache2.4 + php5.6

    相信用惯了Windows的朋友一开始接触Linux是很崩溃的,因为很多东西都是通过命令行来完成的,包括安装绝大多数的开发工具以及环境,那么在Ubuntu下其实可以直接通过apt-get指令来安装apa ...

  2. 微信小程序之点击列表的item带参数跳转界面

    1.在js文件里写个界面跳转的事件处理函数gotableinfo,var index = parseInt(e.currentTarget.dataset.index); 为获取当前点击列表的下脚标, ...

  3. QTP自动化测试

    原文链接:https://www.cnblogs.com/xiezhidong/p/6784684.html ♣Qtp是什么? ♣测试用例网站    ♦注册与登录    ♦测试脚本       ◊录制 ...

  4. Java线程池不错的总结博客

    ImportNew线程池总结 Java多线程之Executor.ExecutorService.Executors.Callable.Future与FutureTask 线程池,这一篇或许就够了

  5. 20164322韩玉婷 -----EXP3 免杀原理与实践

    基础问题回答 1.杀软是如何检测出恶意代码的? (1)基于特征码的检测 特征码是能识别一个程序是一个病毒的一段不大于64字节的特征串.如果一个可执行文件包含这样的特征码则被杀毒软件检测为是恶意代码. ...

  6. HBase应用快速开发

    有人说过“让Hadoop开发像家庭作业一样简单”,容器技术的出现让这成为可能,可以用Docker封装HBase运行环境,通过统一的接口来运行.本文将介绍如何在十分钟内跑起你的HBase应用. 首先,我 ...

  7. SQA计划

    一.SQA计划 1.软件工程 所做程序是一个长沙大学的学习app系统 .可以实现用户的注册登录,课程学习,以及活动参加.根据需求建模,进行体系结构设计,然后设计. 2.质量保证 (1)项目需要符合IE ...

  8. 学习笔记CB008:词义消歧、有监督、无监督、语义角色标注、信息检索、TF-IDF、隐含语义索引模型

    词义消歧,句子.篇章语义理解基础,必须解决.语言都有大量多种含义词汇.词义消歧,可通过机器学习方法解决.词义消歧有监督机器学习分类算法,判断词义所属分类.词义消歧无监督机器学习聚类算法,把词义聚成多类 ...

  9. 谈一谈java中的Canves机制

    0--写在前面: 很多初学java的童鞋,常常很苦恼,一天天的都跟命令行较劲,好像很无聊的样子,如果能跳出命令行做出界面甚至一个画图界面,那将是一件很兴奋的事情:也可以让编程变的有趣:有脑洞的同学还可 ...

  10. [翻译][Java]ExecutorService的正确关闭方法

    https://blog.csdn.net/zaozi/article/details/38854561 https://blog.csdn.net/z69183787/article/details ...