Vue 可输入可下拉组件的封装
由于业务需要,需要一个可输入也可下拉的组件,看了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 可输入可下拉组件的封装的更多相关文章
- js实现可输入的下拉框
<HTML> <HEAD> <META http-equiv='Content-Type' content='text/html; charset=gb2312'> ...
- amazeui学习笔记--js插件(UI增强4)--下拉组件Dropdown
amazeui学习笔记--js插件(UI增强4)--下拉组件Dropdown 一.总结 1.am-dropdown(及其孩子):控制下拉列表的样式 2.data-am-dropdown(及其孩子):控 ...
- vue 表格中的下拉框单选、多选处理
最近在用vue做前后端分离,需要在表格中用到下拉框,由于需求变动,从最开始的单选变为多选,折腾了许久,记录一下,供后人铺路 vue 中的表格下拉框单选 collectionsColnumOptions ...
- Vue自定义指令实现下拉加载:v-loadmore
和methods平级: directives: { loadmore: {//自定义指令: 下拉加载 bind(el, binding) { var p = 0; var t = 0; ...
- vue的jsonp百度下拉菜单
通过vue的jsonp实现百度下拉菜单的请求,vue的版本是2.9.2 <!DOCTYPE html> <html lang="en"> <head& ...
- Html5下拉控件同时支持文本输入和下拉代码
有时候,下拉框不能满足我们的业务需求,还需要同时支持用户输入内容,默认的select标签是不支持用户输入的,下面我说一下原生的select如何支持用户输入,代码如下: <!DOCTYPE htm ...
- vue实现百度搜索下拉提示功能
这段代码用到vuejs和vue-resouece.实现对接智能提示接口,并通过上下键选择提示项,按enter进行搜索 <!DOCTYPE html> <html lang=" ...
- vue 获取数据联动下拉框select ,并解决报Duplicate value found in v-for="...": "". Use track-by="$index" 错误
公司项目中遇到一个问题,联动下拉框,并且数据是使用vue-resource从后台获取的,格式不利于输出联动下拉框,联动下拉框是第一个下拉框输出一个数组里每一项json的一个text值,从而第二下拉框输 ...
- jquery模拟可输入的下拉框
//页面html <div id="select" class="select" > <ul> <c:forEach items= ...
随机推荐
- linux下用命令安装node&pm2
我的安装环境是腾讯云centos7操作系统,并且将安装包下载到了/usr/local/src目录下 一.下载node安装包 1.wget https://npm.taobao.org/mirrors/ ...
- phpStudy 切换版本后没有权限的问题
在httpd-vhosts.conf配置如下: <VirtualHost *:80> ServerName www.jy.com DocumentRoot "C:\htdocs\ ...
- WEB测试专题之测试分类
虽然说是一个功能测试就概括了,但是其实这里面还别有洞天,大概区分为下面几个小类别:WEB测试专题之web测试分类一(1)链接测试链接是Web应用系统的一个主要特征,它是在页面之间切换和指导用户去一些不 ...
- 作业二:构建swap函数
一.swap代码 #include<stdio.h> int main() //主函数部分 { void swap(int *m,int *n); int a,b; int *p1,*p2 ...
- fillder抓包工具详解
https://www.cnblogs.com/yyhh/p/5140852.html
- .net第四章内容总结
4.2) mdi 多文档界面 创建子窗体的childForm.text书上的做法childformnumber不存在 于是我自定义一个childforNumber起始为1: 在窗体下面显示所有已经 ...
- Centos7.4下安装Jumpserver 1.0.0(支持windows组件)
0)系统环境CentOS 7.4 IP: 192.168.100.10 [root@jumpserver-server ~]# cat /etc/redhat-release CentOS Linux ...
- 命令行编译多个java文件
如何使用命令行编译多个java文件 文件结构: method 1 cd javaproject javac -sourcepath javapath -d classpath javapath/*.j ...
- flutter 容器
Flutter 有着丰富的布局控件库 . Flutter 中的布局整体分为 Single-child layout widget (单子布局部件) Multi-child layout widget ...
- MySQL:ERROR 1044 (42000): Access denied for user ''@'localhost' to database 'mysql'
ERROR 1044 (42000): Access denied for user ''@'localhost' to database 'mysql'. 原因是:mysql数据库的user表里,存 ...