vue+el-select实现既能下拉选择,又能直接输入

vue+el-select实现既能下拉选择,又能直接输入

1、官网方式

实现方式:在现有的下拉表单基础上,给el-select添加属性“filterable,allow-create,default-first-option”即可

<template v-for="(taskItem, index) in formInfo.dataList">
	<el-form-item label="类型" :prop="'dataList.' + index + '.lingyu'" :ref="'dataList.' + index + '.lingyu'" class="record-inputs">
	  <el-select 
	    v-model="taskItem.type" 
	    clearable
	    filterable
	    allow-create
	    default-first-option
	    placeholder="请输入或选择" 
	    class="record-input" 
	    :popper-append-to-body="false"
	    >
	    <el-option v-for="(item, index) in lingyu" :key="index" :label="item.label" :value="item.value"></el-option>
	  </el-select>
	</el-form-item>
</template>

上述方式有一个缺点,即失去焦点后会自动清空,效果不好(输入完成后,不能像正确的输入框一样,需要对下拉框进行选择)

2、优化(给value赋值)

添加@blur函数,失去焦点时,执行该方法,将输入的值赋值给绑定的变量

<template v-for="(taskItem, index) in formInfo.dataList">
	<el-form-item label="类型" :prop="'dataList.' + index + '.lingyu'" :ref="'dataList.' + index + '.lingyu'" class="record-inputs">
	  <el-select 
	    v-model="taskItem.type"
	    clearable 
	    filterable
	    allow-create
	    default-first-option
	    placeholder="请输入或选择" 
	    class="record-input" 
	    @blur="e=>selectBlur(e, index)"
	    @change="val=>selectChange(val,index)"
	    :popper-append-to-body="false"
	    >
	    <el-option v-for="(item, index) in lingyu" :key="index" :label="item.label" :value="item.value"></el-option>
	  </el-select>
	</el-form-item>
</template>

method中:

   selectBlur(e,index){
     this.formInfo.dataList[index].lingyu = e.target.value
   },
   selectChange(val,index){
     this.formInfo.dataList[index].lingyu = val
   },

注意:@blur="e=>selectBlur(e, index)"中,是组件方法传参时传自带参数以及其他参数

3、扩展

通常想在组件自带的函数会返回默认的值,有时候想要传递一些自定义的参数
方法1:使用$event

@change="selectChange($event,'aaa')"

方法2:使用箭头回调函数

@change="((val) => selectChange(val,'bbb'))"
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值