vue实现表单单独移除一个字段验证

 更新时间:2022年03月21日 09:04:04   作者:friend_ship  
这篇文章主要为大家详细介绍了vue实现表单单独移除一个字段验证,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

本文实例为大家分享了vue实现表单单独移除一个字段验证的具体代码,供大家参考,具体内容如下

下面的代码以登录功能为例。

功能描述: 用户输入密码时,失去焦点进行密码校验,当输入有误时,显示错误提示信息;只要密码值发生了变化,错误提示信息就移除。

通过watch监控password字段,实现实时移除。

vue2 模板语法代码如下:

<template>
    <div>
         <el-form :model="form" :rules="rules" ref="form" label-width="140px">
          <el-form-item label="用户名" prop="username">
           <el-input v-model="form.username" placeholder="请输入用户名"></el-input>
          </el-form-item>
          <el-form-item label="密码" prop="password">
            <el-input type="password" v-model="form.password" placeholder="请输入密码"
            ></el-input>
          </el-form-item>
          <el-form-item>
            <el-button type="primary" @click="submit('form')">提交</el-button>
            <el-button @click="reset('form')">取消</el-button>
          </el-form-item>
        </el-form>
    <div>
</template>
<script>
export default {
    data() {
        let validatePwd  = (rule, value, callback) => {
            // 密码校验
        }
        return {
            form: {
                username: '',
                password: ''
            },
             rules: {
                username: [{ required: true, message: '请输入用户名', trigger: 'blur'}],
                password: [{ required: true, validator: validatePwd, trigger: 'blur'}]
            }
        }
    },
    watch: {
        'form.password'(newVal, oldVal) {
            if(newVal, oldVal) {
                  this.$refs['form'].clearValidate('password');
            }
        }
    }
 
}
</script>

vue2+composition-api 使用tsx语法开发,代码如下:

service.ts

export const initFormState = {
    username: '',
    password: ''
}
 
const validatePwd = (rule, value, callback) => {
    // 密码校验
}
 
export const formStateRules = {
    username: [
        { required: true, message: '请输入用户名', trigger: 'blur'}
    ],
    password: [
        { required: true, validator: validatePwd, trigger: 'blur'}
    ]
}

index.tsx文件

import { onMounted, reactive, ref, watch } from "@vue/composition-api";
import { initFormState} from './service.ts';
 
export default defineComponent({
    setup (prop,{root}) {
     
        const formState= reactive({
            ...initFormState, // 从service引入进来
        })
 
        const formRef = ref(null);
        
        const submit = ()  => {
            // 表单校验
            const formValidate = await new Promise(resolve => {
                (formRef as any).value.validate((valid: boolean) => resolve(valid));
            });
 
            if(!formValidate) return;
            // 表单校验通过后进行的逻辑
        }
 
        const reset = () => {
             Object.keys(formState).map((key: string) => formState[key] = (initFormState as any)[key]);
        }
    
        // 监控password, 按需移除错误提示信息
       watch(() => formState.password, ()=> {
           const result = formState.password;
            if(result) {
                (formRef as any).value.clearValidate('password')
            }
        })
        return {
            formState,
            formRef,
            formStateRules,
            submit,
            reset
        }
    
    },
    render() {
        return (
            <div>
                <el-form 
                    ref="formRef" 
                    form={this.formState} 
                    props={{model: this.formState}}
                    rules={formStateRules}  label-width="140px">
                  <el-form-item label="用户名" prop="username">
                       <el-input v-model={this.formState.username} placeholder="请输入用户名"></el-input>
                  </el-form-item>
                  <el-form-item label="密码" prop="password">
                    <el-input type="password" v-model={this.formState.password} placeholder="请输入密码"></el-input>
                  </el-form-item>
                  <el-form-item>
                    <el-button type="primary" onClick={this.submit}>提交</el-button>
                    <el-button onClick={this.reset}>取消</el-button>
                  </el-form-item>
                </el-form>
            </div>
        )
    }
 
})

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • vue跳转页面携带参数并且立即执行方法

    vue跳转页面携带参数并且立即执行方法

    这篇文章主要介绍了vue跳转页面携带参数并且立即执行方法,首先定义跳转函数,结合实例代码给大家介绍的非常详细,需要的朋友参考下吧
    2023-10-10
  • vue实现防抖的实例代码

    vue实现防抖的实例代码

    这篇文章主要给大家介绍了关于vue实现防抖的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-01-01
  • 详解用webpack2.0构建vue2.0超详细精简版

    详解用webpack2.0构建vue2.0超详细精简版

    本篇文章主要介绍了详解用webpack2.0构建vue2.0超详细精简版,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-04-04
  • vue项目中全局引入1个.scss文件的问题解决

    vue项目中全局引入1个.scss文件的问题解决

    这篇文章主要跟大家介绍了vue项目中全局引入1个.scss文件的问题解决,文中通过示例代码介绍的非常详细,对大家学习或者使用vue具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-08-08
  • vue使用keep-alive保持滚动条位置的实现方法

    vue使用keep-alive保持滚动条位置的实现方法

    这篇文章主要介绍了vue使用keep-alive保持滚动条位置的实现方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-04-04
  • 深入探究Vue中探究组合式API的奥秘

    深入探究Vue中探究组合式API的奥秘

    Vue 3中引入了组合式API,它是一种新的代码组织方式,旨在让开发者更灵活地组织和重用Vue组件的逻辑,下面我们就来学习一下Vue中常见组合式API的使用吧
    2023-11-11
  • vue3-vite安装后main.ts文件和tsconfig.app.json文件报错解决办法

    vue3-vite安装后main.ts文件和tsconfig.app.json文件报错解决办法

    Vue.js是一个流行的JavaScript框架,它可以帮助开发者构建交互式Web应用程序,这篇文章主要给大家介绍了关于vue3-vite安装后main.ts文件和tsconfig.app.json文件报错解决办法,需要的朋友可以参考下
    2023-12-12
  • vue中使用elementUI组件手动上传图片功能

    vue中使用elementUI组件手动上传图片功能

    Vue是一套构建用户界面的框架, 开发只需要关注视图层, 它不仅易于上手,还便于与第三方库或既有项目的整合。这篇文章主要介绍了vue中使用elementUI组件手动上传图片,需要的朋友可以参考下
    2019-12-12
  • Vue.js项目在apache服务器部署问题解决

    Vue.js项目在apache服务器部署问题解决

    本文主要介绍了Vue.js项目在apache服务器部署问题解决,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-06-06
  • 详解Vue.js——60分钟组件快速入门(上篇)

    详解Vue.js——60分钟组件快速入门(上篇)

    本篇文章主要介绍了Vue.js组件,组件系统是Vue.js其中一个重要的概念,具有一定的参考价值,有需要的可以了解一下。
    2016-12-12

最新评论