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",重置上下文状态,表单隐藏且数据清空。

相关推荐
数据服务生1 天前
五子棋-html版本
前端·html
IT_陈寒1 天前
SpringBoot项目启动速度提升300%?这5个隐藏配置太关键了!
前端·人工智能·后端
小碗细面1 天前
5 分钟上手 Claude 自定义 Subagents
前端·人工智能·ai编程
小J听不清1 天前
CSS 浮动(float)全解析:布局 / 文字环绕 / 清除浮动
前端·javascript·css·html·css3
wuhen_n1 天前
生产环境极致优化:拆包、图片压缩、Gzip/Brotli 完全指南
前端·javascript·vue.js
用户69371750013841 天前
315曝光AI搜索问题:GEO技术靠内容投喂操控答案,新型营销操作全揭秘
android·前端·人工智能
周星星日记1 天前
pnpm为什么成为"最先进的管理包工具"
前端
多厘1 天前
使用 opencode 和灵感写一个 mac App (实操版)
前端·github
Wect1 天前
LeetCode 918. 环形子数组的最大和:两种解法详解
前端·算法·typescript
炫饭第一名1 天前
从前端视角解读 OpenClaw(上):Lit 驱动的 AI 控制网关面板
前端·人工智能·前端框架