ctx 上下文对象控制新增 / 编辑表单显示隐藏的逻辑

1 ctx 上下文对象控制新增 / 编辑表单显示隐藏的逻辑

1.1控制新增 / 编辑表单模板

javascript 复制代码
  <template v-if="ctx.type === 'add' || ctx.type === 'edit'">
      <Add :record="ctx.record" @close="handleClose" @refresh="getList" />
    </template>

1.2 初始状态:表单隐藏

javascript 复制代码
ctx: {
  type: null, // 初始为null,不满足v-if条件
  record: null, // 初始无选中数据
}

1.3 点击「新增」:展示空表单

javascript 复制代码
handleAdd() {
  this.ctx.type = "add"; // 赋值为add,满足v-if条件
  // 无需给record赋值,子组件接收空值,渲染空表单
}

此时 Add 组件显示,且 :record="ctx.record" 传递的是 null,子组件可识别为「新增模式」,展示空白表单。

1.4点击「编辑」:展示带数据的表单

javascript 复制代码
handleEdit(row) {
  this.ctx.type = "edit"; // 赋值为edit,满足v-if条件
  this.ctx.record = row; // 把当前行数据传给record,子组件接收后回显
}

Add 组件显示,且接收了当前行的完整数据,子组件可识别为「编辑模式」,将 record 中的数据回显到表单对应字段。

1.5关闭表单:隐藏并重置

javascript 复制代码
handleClose() {
  this.ctx.type = null; // 置空,隐藏Add组件
  this.ctx.record = null; // 清空选中数据,避免下次打开残留
}

点击子组件的关闭按钮时,触发 @close="handleClose",重置上下文状态,表单隐藏且数据清空。

相关推荐
_codemonster8 小时前
Vue的三种使用方式对比
前端·javascript·vue.js
寻找奶酪的mouse8 小时前
30岁技术人对职业和生活的思考
前端·后端·年终总结
梦想很大很大8 小时前
使用 Go + Gin + Fx 构建工程化后端服务模板(gin-app 实践)
前端·后端·go
We་ct8 小时前
LeetCode 56. 合并区间:区间重叠问题的核心解法与代码解析
前端·算法·leetcode·typescript
张3蜂8 小时前
深入理解 Python 的 frozenset:为什么要有“不可变集合”?
前端·python·spring
无小道8 小时前
Qt——事件简单介绍
开发语言·前端·qt
广州华水科技8 小时前
GNSS与单北斗变形监测技术的应用现状分析与未来发展方向
前端
code_YuJun9 小时前
corepack 作用
前端
千寻girling9 小时前
Koa.js 教程 | 一份不可多得的 Node.js 的 Web 框架 Koa.js 教程
前端·后端·面试