尧图网站建设 尧图网络
  • 首页
  • 关于我们
  • 服务项目
  • 案例展示
  • 建站流程
  • 资讯中心
  • 联系我们
首页/资讯中心/详情

前端获取接口材料流程

前端获取接口材料流程
📅 发布时间:2026/6/19 1:07:38

一、组件初始化阶段

1、初始化响应式状态对象:tablebody。

2、核心状态:

  • 表格高度 ( tableHeight )

  • 数据加载状态 ( tableLoading )

  • 表格数据 ( tableList )

  • 总条数 ( total )

  • 分页参数 ( params ):设置默认分页参数。(第1页,每页50条)

const tableBody = reactive({tableHeight: 600,showTable: true,tableLoading: false,tableList: [],total: 0,params: {pageNum: 1,pageSize: 50,  // 默认每页50条},
});

二、表单和表格配置

1、表单字段:

通过 getFormFields 获取表单配置:

const formDataModel = reactive({});
const formData = computed(() => ({showButtons: false,confirmText: '查询',model: formDataModel,  // 绑定表单数据模型fields: getFormFields(),  // 获取表单字段配置
}));

getFormFields() 返回的表单配置:

[{ prop: 'dw', type: 'input', placeholder: '单位' },{ prop: 'yd', type: 'datePicker', placeholder: '月度' }
]

2、表格列:

通过 getTableColumn 获取表格列配置:

const tableColumn = getTableColumn();

三、组件挂载自动加载数据

onMounted(init);  // 组件挂载时触发数据加载
const init = () => {getTableList();
};

四、核心数据获取方法

const getTableList = async () => {try {tableBody.tableLoading = true;// 合并分页参数和表单参数const params = {...tableBody.params,...formDataModel};const res: any = await getInfoApi(params);if (res.status === 200) {tableBody.tableList = res.data.records || [];tableBody.total = res.data.total ? Number(res.data.total) : 0;} else {ElMessage.warning(res.message);}} finally {tableBody.tableLoading = false;}
};

注:其中 res.status 的 status 为状态名,

不同接口可能会有不同的状态名(如code等),所以需要根据不同情况进行修改 。

1、参数合并策略

const params = {...tableBody.params,  // 分页参数 { pageNum: 1, pageSize: 50 }...formDataModel      // 表单参数 { dw: '单位A', yd: ['2023-01', '2023-06'] }
};

合并后的请求参数示例:

{"pageNum": 1,"pageSize": 50,"dw": "单位A","yd": ["2023-01", "2023-06"]
}

2、多种解构方式 

功能/解构方式直接解构:data.rows对象访问:res.data.rows
API调用

const { data, code, message }

= await pageApi(params);

const res: any

= await getInfoApi(params);

状态码检查if (code === 200) if (res.status === 200) 
数据赋值tableBody.tableList = data.rows;tableBody.tableList = res.data.records;

3、响应数据处理

1.直接赋值

特点:保持原始结构 + 分页信息。

其中records要与接口返回的数组名一致。

如若是"list": [...],那么就得是res.data.list。

tableBody.tableList = res.data.records || [];  // 表格数据
tableBody.total = Number(res.data.total) || 0; // 总数

假设后端返回数据结构: 

{"status": 200,"data": {"records": [...],  // 当前页数据"total": 1250      // 总记录数}
}

2.字段映射

特点:必须转换 + 空安全

orgTypeList.value = (data as OrgItem[]).map(item => ({label: item.name,value: item.id,

 转换过程:

// 原始数据
[{ name: "米哈油", id: "org-001" }]
// 转换后(丢弃id,保留label/value)
[{ label: "米哈油", value: "org-001" }]

为什么一定要转换为 { label, value } 格式?

  1. 适配 UI 组件的数据格式
  2. 统一处理逻辑
  3. 减少不必要的数据处理
  4. 清晰分离显示值与存储值

在少数简单场景下可以直接使用原始数据:

  • 纯字符串/数字的简单列表
  • 组件明确支持自定义字段映射

五、用户交互触发点

1、查询按钮

const submitHandler = () => {console.log('Form Data Model:', formDataModel);init();  // 触发数据加载
};

2、数据统计按钮

const dataStatistics = () => {init();  // 同样触发数据加载
};

3、表格刷新/分页

注:该代码所在文件位置:index.vue。



六、动态列显示

按需求选择哪些列显示,哪些列不显示。

1. 表格操作组件引用index


2. 动态列计算属性hooks

const realTableColumn = computed(() =>tableOperateRef.value?.realTableColumn ?? []
);

3. 表格组件绑定index

相关新闻

  • APEX实战第5篇:利用APEX程序直观体验向量近似检索能力
  • 告别复制粘贴!Chat2File-DeepSeek 让 DeepSeek 对话成果直接变“成品” - 指南
  • 构建易受攻击的AWS DevOps环境:CloudGoat场景实践

最新新闻

  • 医疗AI落地两大硬坎:临床信任断裂与数据合规失焦
  • Adaboost原理深度解析:理解梯度提升家族的基石
  • 股市语言密码:看懂全球资本流动的翻译之道
  • 终极指南:如何为300+车型部署开源驾驶辅助系统openpilot
  • 2026年文旅行业GEO优化公司“全意图”价值评估指南与选型避坑 - GEO优化
  • MPC857T外部总线接口:对齐、仲裁与原子操作实战解析

日新闻

  • 5分钟掌握Python进化算法:Geatpy高性能优化工具完全指南
  • Microchip 24AA044 EEPROM选型与应用全指南:从参数解析到实战编程
  • 华为的鸿蒙到底有多牛?为什么称作遥遥领先?

周新闻

  • 3步解锁iOS设备:applera1n激活锁绕过完全指南
  • 39 2026 人工智能证书终极盘点,普通人选 AI 证书可以从这些方向入手
  • Redis 暴露公网有多危险?从端口检查到补救步骤

月新闻

  • 【总结】入门篇:50句话让你记住架构核心概念
  • WeChatMsg技术方案解析:实现Mac微信数据自主管理的完整解决方案
  • WeChatMsg:革新性微信数据备份方案,打造你的专属数字记忆库

关于尧图

  • 公司简介
  • 团队介绍
  • 企业文化
  • 荣誉资质

服务项目

  • 定制开发
  • 电商建站
  • UI 设计
  • 运维服务

快速链接

  • 案例展示
  • 建站流程
  • 常见问题
  • 资讯中心

联系方式

  • 📍北京市朝阳区互联网产业园 A 座 10 层
  • 📞400-888-8888
  • ✉️contact@rkmt.cn
  • 🕐周一至周日 9:00-21:00

© 2024 北京尧图网络科技有限公司 版权所有 | 京 ICP 备 XXXXXXXX 号