十二、VUE基础学习篇(key指令的使用)-清除表单元素切换遗留之前元素的内容

码云实时更新学习demo地址:https://gitee.com/dxl96/vuexuexi

VUE基础篇(key指令的使用)

请看案例:

  <!--没有添加key的情况-->
  <p style="color: red">没有添加key的情况</p>
  <span v-if="isUser">
    <lable for="userName">用户名称</lable>
    <input type="text" id="userName" placeholder="请输入用户名">
  </span>
  <span v-else>
    <lable for="email">用户邮箱</lable>
    <input type="text" id="email" placeholder="请输入邮箱">
  </span>
  <button @click="isUser = !isUser">切换类型</button>
  <br><br>

效果:
在这里插入图片描述
■小问题:
口如果我们在有输入内容的情况下,切换了类型,我们会发现文字依然显示之前的输入的内容。
口但是按道理讲,我们应该切换到另外一input元素中了.
口在另一个input元素中,我们并没有输入内容.
口为什么会出现这个问题呢?
■问题解答:
口这是因为Vue在进行DOM渲染时,出于性能考虑,会尽可能的复用已经存在的元素,而不是重新创建新的元素
口在上面的案例中, Vue内部会发现原来的input元素不再使用,直接作为else中的input来使用了.
■解决方案:
口如果我们不希望Vue出现类似重复利用的问题,可以给对应的input添加key.
口并且我们需要保证key的值不同,这样vue解析就不会复用了

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>点击切换登录方式</title>
</head>
<body>
<div id="app">
  <!--没有添加key的情况-->
  <p style="color: red">没有添加key的情况</p>
  <span v-if="isUser">
    <lable for="userName">用户名称</lable>
    <input type="text" id="userName" placeholder="请输入用户名">
  </span>
  <span v-else>
    <lable for="email">用户邮箱</lable>
    <input type="text" id="email" placeholder="请输入邮箱">
  </span>
  <button @click="isUser = !isUser">切换类型</button>
  <br><br>

  <!--添加了key的情况-->
  <p style="color: red">添加了key的情况</p>
  <span v-if="isUser2">
    <lable for="userName2">用户名称</lable>
    <input type="text" id="userName2" placeholder="请输入用户名" key="userName2">
  </span>
  <span v-else>
    <lable for="email2">用户邮箱</lable>
    <input type="text" id="email2" placeholder="请输入邮箱" key="email2">
  </span>
  <button @click="isUser2 = !isUser2">切换类型</button>
</div>
<!--■上面这种写法在我们点击“切换类型”按钮时,如果输入框输入了内容,在我们切换到不同的input时内容并不会被清空-->
<!--
■小问题:
  口如果我们在有输入内容的情况下,切换了类型,我们会发现文字依然显示之前的输入的内容。
  口但是按道理讲,我们应该切换到另外一input元素中了.
  口在另一个input元素中,我们并没有输入内容.
  口为什么会出现这个问题呢?
■问题解答:
  口这是因为Vue在进行DOM渲染时,出于性能考虑,会尽可能的复用已经存在的元素,而不是重新创建新的元声.
  口在上面的案例中, Vue内部会发现原来的input元素不再使用,直接作为else中的input来使用了.
■解决方案:
  口如果我们不希望Vue出现类似重复利用的问题,可以给对应的input添加key.
  口并且我们需要保证key的不同.
-->
<script src="../../js/vue.js"></script>
<script>
  const app = new Vue({
    el: "#app",
    data: {
      isUser: true,
      isUser2: true
    }
  });
</script>
</body>
</html>

效果
在这里插入图片描述

### 正确刷新 Element UI `el-form` 组件的表单验证 为了确保 `el-form` 的验证状态能够被正确重置,可以调用内置方法来清除之前的验证错误提示并重新初始化表单项的状态。具体操作可以通过组合使用 `resetFields()` 和手动触发验证的方法实现。 当页面加载或特定事件发生时,如果希望清空当前填写的数据以及移除所有的校验结果,应当执行: ```javascript this.$refs.formName.resetFields(); ``` 此命令会遍历所有注册过的字段,并将其恢复到初始未编辑状态的同时消除任何已有的报错信息[^1]。 对于某些场景下可能存在的缓存问题或是异步更新引起的同步问题,则可以在上述基础上进一步采取措施以保障视图层与数据模型之间的一致性。例如,在 Vue 生命周期钩子函数内或者响应式侦听器里加入延迟处理逻辑,给浏览器渲染队列留出时间窗口以便完成 DOM 更新过程后再进行下一步动作;也可以尝试强制 key 变化的方式来促使整个组件实例销毁重建从而达到彻底刷新的效果。 另外得注意的是,若自定义了一些特殊的业务规则或者是非标准类型的控件参与到了整体流程之中,那么除了依赖框架自带的功能外还需要额外编写相应的辅助代码配合工作,比如监听 input 事件即时反馈用户的交互行为改变标记位等手段提高用户体验度[^3]。 #### 刷新表单验证的具体实践案例 下面给出一段完整的 JavaScript 实现片段用于展示如何在一个按钮点击之后安全有效地清理掉之前遗留下来的验证痕迹并且让新的输入再次接受检验: ```html <template> <div> <!-- 定义一个具有唯一 ref 属性名 'ruleForm' 的 el-form --> <el-form :model="form" status-icon :rules="rules" ref="ruleForm"> ... </el-form> <!-- 添加一个按钮用来触发表单重置功能 --> <el-button @click="handleReset('ruleForm')">重置</el-button> </div> </template> <script> export default { methods: { handleReset(formName) { this.$nextTick(() => { // 确保DOM已经完全更新完毕再继续往下走 this.$refs[formName].resetFields(); // 清理所有字段的内容及其关联样式类 }); } }, }; </script> ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值