element-ui中远程搜索select
element
A Vue.js 2.0 UI Toolkit for Web
项目地址:https://gitcode.com/gh_mirrors/eleme/element
免费下载资源
·
项目中有下拉框,需求:获取焦点,可以让用户选择,也可以让用户在输入框中输入,实现模糊搜索,也可以多选。因为使用element-ui,所以就使用了select的高级用法,需求如下图所示
我们以代码的形式进行呈现
<template>
<div class="short-visit">
<el-form :model="ruleForm" :rules="rules" ref="ruleForm" label-width="130px" class="demo-ruleForm" v-if="textFlag">
<el-form-item label="出访国家(地区)" prop="foreignName" class="nation-select">
<el-select
style="min-height: 30px;line-height: 30px;height: auto;"
class="selects"
v-model="ruleForm.foreignName"
multiple
filterable
remote
reserve-keyword
:multiple-limit="3"
@focus="tt"
:remote-method="remoteMethod"
placeholder="请选择国家">
<el-option
v-for="item in options4"
:key="item.value"
:label="item.label"
:value="item.value">
</el-option>
</el-select>
<div class="titles">提示:如出访台湾地区,请按照国际处网页赴台流程及所需材料进行线下审批。</div>
</el-form-item>
<el-form-item class="submitBtn">
<el-button type="primary" @click="submitForm('ruleForm')">提交</el-button>
</el-form-item>
</div>
</template>
<script>
import api from '../../utils/api'
export default {
name: 'short-visit',
data () {
uploadUrl: '',
ruleForm: {
foreignName: [], // 出访国家
},
options4: [],
list: [],
rules: {
foreignName: [
{ required: true, message: '请选择国家', trigger: 'change' }
]
}
}
},
created () {
/**
* 国家的请求
* */
this.getContryData()
},
methods: {
/**
* 数据的提交
* */
submitForm (formName) {
this.$refs[formName].validate((valid) => {
if (valid) {
this.$confirm('是否确认提交', {
confirmButtonText: '确定',
cancelButtonText: '取消',
type: 'warning',
center: true
}).then(() => {
}).catch(() => {
})
} else {
return false
}
})
},
/**
* 国家
* */
getContryData () {
api.getContrys().then((res) => {
// console.log(res)
// console.log(res.data.code)
if (res.data.code === 0) {
for (var i = 0; i < res.data.data.length; i++) {
let obj = {}
obj.value = res.data.data[i].codeLabel
obj.codeValue = res.data.data[i].codeValue
this.list.push(obj)
}
// console.log(this.ruleForm.foreignName)
}
})
},
/**
* 选择国家获取焦点
* */
tt () {
this.options4 = this.list
console.log(this.options4)
},
/**
* 选择国家
* */
remoteMethod (query) {
console.log(query)
if (query !== '') {
this.loading = true
setTimeout(() => {
this.loading = false
this.options4 = this.list.filter(item => {
return item.value.toLowerCase()
.indexOf(query.toLowerCase()) > -1
})
}, 200)
} else {
this.options4 = []
}
}
}
}
</script>
<style rel="stylesheet/scss" lang="scss">
</style>
上面当el-select获取焦点的时候,我们把请求到的数据复制给option4,页面做一个渲染,当我们输入实现模糊搜索的时候,使用的是过滤。
我在处理数据的时候,push进去的是value跟codeValue,在做循环,我们理所当然用的value跟codeValue。当我们只输入的时候,没有问题,但我们只选择的时候,也没有任何问题,但是有一部分是输入搜索得到,有一部分是选择得到,就会出现问题,input中你选择的值就不合适了。经过检查,最终以上面代码的解决方法解决,是没有任何问题的。
GitHub 加速计划 / eleme / element
54.06 K
14.63 K
下载
A Vue.js 2.0 UI Toolkit for Web
最近提交(Master分支:3 个月前 )
c345bb45
7 个月前
a07f3a59
* Update transition.md
* Update table.md
* Update transition.md
* Update table.md
* Update transition.md
* Update table.md
* Update table.md
* Update transition.md
* Update popover.md 7 个月前
更多推荐
已为社区贡献4条内容
所有评论(0)