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 天前
Lambda 表达式、方法引用(Method Reference)语法
java·前端·servlet
石小石Orz1 天前
油猴脚本实现生产环境加载本地qiankun子应用
前端·架构
从前慢丶1 天前
前端交互规范(Web 端)
前端
CHU7290351 天前
便捷约玩,沉浸推理:线上剧本杀APP功能版块设计详解
前端·小程序
GISer_Jing1 天前
Page-agent MCP结构
前端·人工智能
王霸天1 天前
💥别再抄网上的Scale缩放代码了!50行源码教你写一个永不翻车的大屏适配
前端·vue.js·数据可视化
小领航1 天前
用 Three.js + Vue 3 打造炫酷的 3D 行政地图可视化组件
前端·github
@大迁世界1 天前
2026年React大洗牌:React Hooks 将迎来重大升级
前端·javascript·react.js·前端框架·ecmascript
PieroPc1 天前
一个功能强大的 Web 端标签设计和打印工具,支持服务器端直接打印到局域网打印机。Fastapi + html
前端·html·fastapi
悟空瞎说1 天前
深入 Vue3 响应式:为什么有的要加.value,有的不用?从设计到源码彻底讲透
前端·vue.js