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

相关推荐
天渺工作室5 小时前
实现一个adblock/adblock plus等浏览器广告拦截器检测插件
前端·javascript
阳光是sunny5 小时前
Vue 项目怎么做用户行为全链路监控?轻量插件方案详解
前端·面试·架构
ZhengEnCi6 小时前
Q04-Vite禁用CSS代码分割-解决生产环境样式加载顺序混乱问题
前端·vue.js·vite
九酒6 小时前
AI Agent 开发踩坑记:口播功能非得用 APP 原生实现吗?
前端·人工智能·agent
Jackson__7 小时前
做了一段时间的AI coding后,我终于搞清了 CLI 和 MCP 的区别
前端·agent·ai编程
IT_陈寒9 小时前
JavaScript项目实战经验分享
前端·人工智能·后端
用户479492835691510 小时前
6w star,GitHub 趋势第一的 Ponytail,这个agent插件到底在火什么
前端·后端
薛定喵的谔11 小时前
我开源了一个精致的 Next.js 博客模板:Skyplume
前端·前端框架·next.js
张龙68712 小时前
构建生产级 AI Agent:工具调用与记忆架构实战指南
前端
kyriewen13 小时前
2026 年了,还在用 Node.js?Bun 迁移实战:20 分钟搞定,附踩坑记录
前端·javascript·node.js