uni-app中vue3表單校驗失敗的問題及解決方法
1.問題
在app中使用uni-forms表單,并添加校驗規(guī)則,問題是即使輸入內(nèi)容,表單校驗依然失敗。
代碼:
<template>
<view>
<uni-forms ref="seedForm" :model="formData" :rules="rules" label-position="top">
<uni-forms-item label="姓名" name="name">
<input type="text" v-model="formData.name" placeholder="請輸入姓名" />
</uni-forms-item>
<uni-forms-item label="郵箱" name="email">
<input class="input" v-model="formData.email" type="text" placeholder="請輸入郵箱" />
</uni-forms-item>
</uni-forms>
<button @click="submit">Submit</button>
</view>
</template>
<script lang="ts" setup>
import { onReady } from "@dcloudio/uni-app";
import { ref } from "vue";
const seedForm = ref();
const resetForm = () => {
return {
name: '',
email: ''
}
};
let formData = resetForm();
const rules = {
// 對name字段進行必填驗證
name: {
rules: [{
required: true,
errorMessage: '請輸入姓名'
},
{
minLength: 3,
maxLength: 5,
errorMessage: '姓名長度在 {minLength} 到 {maxLength} 個字符'
}],
},
// 對email字段進行必填驗證
email: {
rules: [{
required: true,
errorMessage: '請輸入郵箱'
}],
}
};
onReady(() => {
seedForm.value.setRules(rules);
})
const submit = async () => {
console.log(formData.value);
// 1.
// try {
// await seedForm.value?.validate?.()
// console.log("校驗通過");
// } catch (error){
// console.log("校驗失敗");
// }
// 2.
seedForm.value.validate().then(async ({ valid } : any) => {
if (valid) {
console.log("校驗失敗");
} else {
//驗證成功
console.log("校驗成功");
}
});
// 3.
// seedForm.value.validate(valid => {
// if (!valid) {
// console.log("校驗成功");
// } else {
// console.log('驗證失敗');
// console.log(valid);
// }
// });
// 4.
// seedForm.value.validate().then(res => {
// console.log('表單數(shù)據(jù)信息:', res);
// // 清除驗證
// // form.value.clearValidate()
// }).catch(err => {
// console.log('表單錯誤信息:', err);
// })
}
</script>
<style>
</style>2.原因及解決方式
表單綁定的數(shù)據(jù)不正確,外面需要套一層ref,聲明響應式數(shù)據(jù)綁定到表單中。之前的那個寫法確實不報錯,但是不能把表單中輸入的數(shù)據(jù)更新到formData中,導致校驗一直報錯。
修改前: let formData = resetForm(); 修改后: let formData = ref(resetForm());
3.表單校驗方式(vue3)
定義校驗規(guī)則-》修改表單結構-》綁定表單數(shù)據(jù)-》提交時校驗
表單規(guī)則中各個項目的id要和表單中form-item中的name屬性一致。
在vue中表單數(shù)據(jù)通過ref方式進行定義。
表單中需要追加rule,ref及model,分別定義校驗規(guī)則,表單及表單綁定的數(shù)據(jù)
提交表單時校驗方式有好幾種。主要是先定義表單實例,通過表單實例中的value的validate判斷校驗是成功還是失敗。
我上面的代碼中一共有4中校驗方式。第二種前端會報錯,可以參照下其他幾種方式。

補充:
關于uniapp開發(fā)使用uni-ui組件表單校驗一直不通過的原因及解決方案
今天使用uniapp開發(fā)東西的時候,發(fā)現(xiàn)我的表單校驗一直通不過,后面才發(fā)現(xiàn)少東西了。我在uni-forms上少放了modelValue,但在官方文檔上沒有提示。所以要做驗證必須加這個屬性。
因為直接像下面這樣寫也是可以雙向綁定的,誰能想到,
<uni-easyinput v-model="drawerData.name" placeholder="" />
uni-forms表單校驗必加屬性:
:rules=""http://這是校驗規(guī)則 :modelValue=""http://這是要校驗的數(shù)據(jù)對象 uni-forms-item 的name屬性和表單v-model的屬性值保持一直 <uni-forms ref="drawerform" label-width="80" :rules="rules" class="drawer-form" :model="drawerData">
rules: {//表單校驗規(guī)則
name: {
rules: [{
required: true,
errorMessage: '請輸入商品名稱',
trigger: ['blur', 'change']
},
{
minLength: 2,
errorMessage: '名稱兩個字符以上',
}
],
label:"商品名稱"
},
}至于校驗規(guī)則根據(jù)官方網(wǎng)站來就行了,細心一點就沒問題
到此這篇關于uni-app中vue3表單校驗失敗的文章就介紹到這了,更多相關uni-app表單校驗失敗內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
vue中@click和@click.native.prevent的區(qū)別
這篇文章主要介紹了vue中@click和@click.native.prevent的區(qū)別,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-04-04
解決vue3+vite配置unplugin-vue-component找不到Vant組件
這篇文章主要為大家介紹了vue3+vite配置unplugin-vue-component找不到Vant組件問題解決,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-09-09
Element Plus暗黑模式及模式自由切換的實現(xiàn)
本文詳細介紹了如何在使用Vite構建的Vue項目中實現(xiàn)ElementPlus暗黑模式及模式切換,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2024-11-11
mpvue小程序循環(huán)動畫開啟暫停的實現(xiàn)方法
這篇文章主要介紹了mpvue小程序循環(huán)動畫開啟暫停的實現(xiàn)方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2019-05-05

