VUE3+Element-plus中el-form的使用示例代码

 更新时间:2024年07月06日 10:15:44   作者:尘烟生活家  
这篇文章主要介绍了VUE3+Element-plus中el-form的使用示例代码,本文通过图文示例代码相结合给大家介绍的非常详细,需要的朋友可以参考下

实现效果

Element-plus使用el-form必须配置ref和model属性,二者的值不能相同(在ElementUI中是可以相同的)。ref的值在声明的时候要引入FormInstance,这个又必须在script中声明lang为ts,不能使用js。这样就必须引入对ts的支持​

step 1:安装vue-loader和vue-template-compiler

step 2:安装typescript​

step 3:安装ts-loader​

关键点

1.el-form的ref和model属性的参数值必须不一样,否则会冲突

2.每个el-form-item必须设置prop属性,否则重置方法resetFields不生效

3.重置方法使用的formRef后面需要增加.value,因为声明的是ref。否则重置方法resetFields不生效

4.要控制表单项的布局,使用el-row和el-col是不错的方法,易于控制

完整代码

​<template>
<div>
<el-form :model="form" ref="formRef" >
        <el-row>
          <el-col :span="10">
            <el-form-item label="邮箱" prop="email">
                <el-input v-model="form.email"></el-input>
            </el-form-item>
          </el-col>
          <el-col :span="10">
            <el-form-item label="姓名" prop="name">
                <el-input v-model="form.name"></el-input>
            </el-form-item>
          </el-col>
        </el-row>
	<el-form-item>
          <el-button type="primary" @click="submitForm(productId,username)">提交</el-button>
          <el-button @click="resetForm">重置</el-button>
        </el-form-item>
      </el-form>
    </div>
</template>
<script lang="ts" setup>
import type {FormInstance} from "element-plus";
const formRef=ref<FormInstance>()
function resetForm() {
  console.log('this.form',form)
  formRef.value.resetFields()
}
</script>

​增加表单项的校验规则

如果要设置每个el-form-item的校验规则,需要引入FormRules,安装如下方式使用,关键点如下:

1.在el-form设置rules属性

2.引入FormRules

3.声明一个interface,例如RuleForm

4.使用reactive声明model关联的参数form,模板类型为RuleForm

5.使用reactive声明rules关联的参数curRules,模板类型为FormRules<RuleForm>

​
<el-form :model="form" ref="formRef" :rules="curRules">
//...
import type {FormRules} from "element-plus";
interface RuleForm{
  email: String
  name: String
}
let form=reactive<RuleForm>({
  email: '',
  name: '',
})
let curRules=reactive<FormRules<RuleForm>>({
  email: [
    {required: true, message: '请输入邮箱', trigger: 'blur'},
    {type: 'email', message: '请输入正确的邮箱地址', trigger: ['blur', 'change']}
  ],
  name: [
    {required: true, message: '请输入姓名', trigger: 'blur'}
  ]
)

到此这篇关于VUE3+Element-plus中el-form的使用的文章就介绍到这了,更多相关vue3 Element-plus el-form使用内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • vue编译打包本地查看index文件的方法

    vue编译打包本地查看index文件的方法

    下面小编就为大家分享一篇vue编译打包本地查看index文件的方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-02-02
  • vue父组件通过props如何向子组件传递方法详解

    vue父组件通过props如何向子组件传递方法详解

    在Vue 中,可以使用 props 向子组件传递数据,下面这篇文章主要给大家介绍了关于vue父组件通过props如何向子组件传递方法的相关资料,文中通过示例代码介绍的非常详细,需要的朋友可以参考借鉴,下面来一起看看吧。
    2017-08-08
  • Vue 3.0的attribute强制行为理解学习

    Vue 3.0的attribute强制行为理解学习

    这篇文章主要为大家介绍了Vue 3.0的attribute强制行为理解学习,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-08-08
  • vue中el-tree 横向滚动条的实现

    vue中el-tree 横向滚动条的实现

    本文详细介绍了在Vue框架中使用el-tree组件创建横向滚动条的方法,通过代码示例和步骤说明,帮助开发者理解和实现横向滚动功能,感兴趣的可以了解一下
    2024-09-09
  • 五种Vue实现加减乘除运算的方法总结

    五种Vue实现加减乘除运算的方法总结

    这篇文章主要为大家详细介绍了五种Vue实现加减乘除运算的方法,文中的示例代码简洁易懂,对我们深入了解vue有一定的帮助,需要的可以了解下
    2023-08-08
  • vue的基本用法与常见指令

    vue的基本用法与常见指令

    Vue.js是JavaScript MVVM(Model-View-ViewModel)库,十分简洁,Vue核心只关注视图层,相对AngularJS提供更加简洁、易于理解的API。接下来通过本文给大家介绍vue的基本用法与常见指令,感兴趣的朋友一起看看吧
    2017-08-08
  • elementUI checkBox报错Cannot read property 'length' of undefined解决

    elementUI checkBox报错Cannot read property &ap

    这篇文章主要为大家介绍了elementUI checkBox报错Cannot read property 'length' of undefined的解决分析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-06-06
  • vue中利用pinyin-pro纯前端实现拼音的模糊搜索功能

    vue中利用pinyin-pro纯前端实现拼音的模糊搜索功能

    这篇文章主要介绍了vue中利用pinyin-pro纯前端实现拼音的模糊搜索,实现思路很简单,通过安装配置插件编写工具类,本文结合实例代码给大家介绍的非常详细,需要的朋友可以参考下
    2022-11-11
  • vue axios请求拦截实例代码

    vue axios请求拦截实例代码

    axios 是一个基于Promise 用于浏览器和 nodejs 的 HTTP 客户端.这篇文章主要介绍了vue/axios请求拦截的相关知识,需要的朋友可以参考下
    2018-03-03
  • Vue高性能列表GridList组件及实现思路详解

    Vue高性能列表GridList组件及实现思路详解

    这篇文章主要为大家介绍了Vue高性能列表GridList组件及实现思路详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-11-11

最新评论