uniapp的uni-form-item放入第三方下拉框组件,并且没用v-model双向绑定,如何校验
时间: 2023-07-05 18:18:06 浏览: 340
如果uni-form-item中放入第三方下拉框组件,并且没有使用v-model双向绑定,也可以通过配合uni-form-item的`rules`属性来进行校验。具体步骤如下:
1. 在uni-form-item中使用 `ref` 属性引用该下拉框组件,例如 `ref="mySelect"`。
2. 在 `rules` 属性中添加自定义校验规则,通过 `validator` 属性指定一个函数来实现校验逻辑。在该函数中,可以通过 `$refs` 来获取下拉框组件实例,并判断选中的值是否合法。
示例代码如下:
```html
<template>
<view>
<uni-form>
<uni-form-item label="下拉框" prop="mySelect" ref="myFormItem" :rules="[{validator: validateSelect, message:'请选择下拉框内容'}]">
<my-select ref="mySelect"></my-select>
</uni-form-item>
<uni-button @click="submit">提交</uni-button>
</uni-form>
</view>
</template>
<script>
export default {
methods: {
validateSelect(rule, value, callback) {
// 通过 $refs 获取下拉框组件实例
const mySelect = this.$refs.mySelect
// 判断选中的值是否合法
if (mySelect && mySelect.selectedValue) {
callback()
} else {
callback(new Error(rule.message))
}
},
submit() {
// 调用 uni-form 组件的 validate 方法进行校验
this.$refs.myFormItem.validate((valid) => {
if (valid) {
// 校验通过,执行提交操作
console.log('submit')
} else {
// 校验不通过,提示错误信息
uni.showToast({
title: '表单校验未通过',
icon: 'none'
})
}
})
}
}
}
</script>
```
在上述代码中,我们在 `rules` 属性中添加了一个自定义校验规则,并通过 `$refs` 来获取下拉框组件实例,在 `validator` 属性指定的函数中判断选中的值是否合法。在 `submit` 方法中,我们通过 `this.$refs.myFormItem.validate` 调用了 uni-form-item 的 `validate` 方法来进行表单校验,如果校验通过则执行提交操作,否则提示错误信息。
阅读全文