1.实现表单重置功能

1.1 当点击重置按钮时,重置整个表单数据验证结果

elementui radio表单回显 element ui表单重置_vue.js

1.2 如何实现重置功能

① 首先查看官方文档API,往下拉找到Form Methods方法,组件 | Element

elementui radio表单回显 element ui表单重置_表单_02

② API 提供了一个重置方法 resetFields。表单重置的原理是,只要获取了表单的实例对象,就可以通过实例对象,直接访问resetFields 这个函数。从而实现对表单的重置。

③ 那么,接下来。思路有了,只需要拿到表单实例对象,通过实例对象调用resetFields 就能够实现重置。

1.3 如何获取到表单的实例对象

① 例如,我们希望拿到 el-form 组件的实例对象,只需要给该组件添加一个 ref 引用,ref的值,等于一个引用名称。引用名称没有要求,合法就行。

elementui radio表单回显 element ui表单重置_vue.js_03

Ref引用定义完成后,只需要获取到loginFormRef (自定义的引用名称),就能拿到表单的实例对象。换句话说,自定义的引用名称(loginFormRef ) 就是表单的实例对象。可以直接通过loginFormRef 调用resetFields 函数,实现表单重置功能。

1.4 为重置按钮绑定单击事件,实现重置功能 

elementui radio表单回显 element ui表单重置_javascript_04

① 添加按钮绑定事件

elementui radio表单回显 element ui表单重置_表单_05

③ 到数据行为区域,定义处理函数 methods 函数。跟data()同一级别。methods函数里面放自定义的点击事件函数 resetLoginForm

elementui radio表单回显 element ui表单重置_elementui radio表单回显_06

④ 当点击按钮时,触发事件通过this 指向当前组件实例对象。

elementui radio表单回显 element ui表单重置_表单_07

 1.5 总结

  1. 为表单添加ref 引用,ref的值就是组件的实例对象。
  2. 通过 this 访问到 $refs . (点)出来表单引用对象,然后直接调用resetFields()方法,重置整个表单。

1.6 代码

<template>
  <div class="login_container">
    <div class="login_box">
      <!-- 头像区域 -->
      <div class="avatar_box">
        <img src="../assets/logo.png" alt="" />
      </div>
      <!-- 登录表单区域 -->
      <el-form ref="loginFormRef" :model="loginForm" :rules="loginFormRules" label-width="0px" class="login_form">
        <!-- 用户名 -->
        <el-form-item prop="username">
          <el-input
            v-model="loginForm.username"
            prefix-icon="iconfont icon-yonghu"
          >
          </el-input>
        </el-form-item>
        <!-- 密码 -->
        <el-form-item prop="password">
          <el-input
            v-model="loginForm.password" type="password"
            prefix-icon="iconfont icon-mima"
          >
          </el-input>
        </el-form-item>
        <!-- 按钮区域 -->
        <el-row justify="end">
          <el-form-item class="login_btn">
            <el-button type="primary">登录</el-button>
            <el-button type="info" @click="resetLoginForm">重置</el-button>
          </el-form-item>
        </el-row>
      </el-form>
    </div>
  </div>
</template>

<script>
export default {
  data () {
    return {
      // 这是登录表单的数据绑定对象
      loginForm: {
        username: '',
        password: ''
      },
      // 这是表单的验证规则对象
      loginFormRules: {
        // 验证用户名是否合法
        username: [
          { required: true, message: '请输入登录名称', trigger: 'blur' },
          { min: 3, max: 10, message: '长度在 3 到 10 个字符', trigger: 'blur' }
        ],
        // 验证密码是否合法
        password: [
          { required: true, message: '请输入登录密码', trigger: 'blur' },
          { min: 6, max: 15, message: '长度在 6 到 15 个字符', trigger: 'blur' }
        ]
      }
    }
  },
  methods: {
    resetLoginForm () {
      this.$refs.loginFormRef.resetFields()
    }
  }
}

</script>

<style lang="less" scoped>
.login_container {
  background-color: #2b4b6b;
  height: 100vh;
}
.login_box {
  // 宽450像素
  width: 450px;
  // 高300像素
  height: 300px;
  // 背景颜色
  background-color: #fff;
  // 圆角边框3像素
  border-radius: 3px;
  // 绝对定位
  position: absolute;
  // 距离左则50%
  left: 50%;
  // 上面距离50%
  top: 50%;
  // 进行位移,并且在横轴上位移-50%,纵轴也位移-50%
  transform: translate(-50%, -50%);
  .avatar_box {
    // 盒子高度130像素
    height: 130px;
    // 宽度130像素
    width: 130px;
    // 边框线1像素 实线
    border: 1px solid #eee;
    // 圆角
    border-radius: 50%;
    // 内padding
    padding: 10px;
    // 添加阴影 向外扩散10像素 颜色ddd
    box-shadow: 0 0 10px #ddd;
    // 绝对定位
    position: absolute;
    // 距离左则
    left: 50%;
    // 位移
    transform: translate(-50%, -50%);
    // 背景
    background-color: #fff;
    img {
      width: 100%;
      height: 100%;
      border-radius: 50%;
      background-color: #eee;
    }
  }
}
.login_form {
  position: absolute;
  bottom: 0;
  width: 100%;
  padding: 0 20px;
  box-sizing: border-box;
}
.login_btn {
  // 设置弹性布局
  display: flex;
  // 横轴上尾部对齐
  justify-content: flex-end;
}
</style>