当前位置: 首页 > wzjs >正文

网站推广公司运营模式营销策划公司排行榜

网站推广公司运营模式,营销策划公司排行榜,中装建设集团有限公司,中国城市建设官方网站代码优化-循环嵌套关联请求 1. 背景 在实际开发中,我们经常会遇到需要嵌套关联请求的场景,比如: 获取项目列表获取项目详情获取项目进度 2. 问题 在这种场景下,我们可能会遇到以下问题: 串行请求瀑布流&#xff…

代码优化-循环嵌套关联请求

1. 背景

在实际开发中,我们经常会遇到需要嵌套关联请求的场景,比如:

  • 获取项目列表
  • 获取项目详情
  • 获取项目进度

2. 问题

在这种场景下,我们可能会遇到以下问题:

  1. 串行请求瀑布流:for循环内的await导致接口调用时间叠加
  2. 状态依赖耦合:进度请求依赖前序请求的状态结果
  3. 数据合并冗余:多次对象赋值操作影响性能
  4. 错误处理缺失:任意请求失败会导致整个流程中断
  5. 状态映射重复:每次处理状态都进行数组查找
    async loadProjectData() {this.loading = true;try {const res = await this.$api.projectService.AA({ clientId: this.customer.clientId });if (res.code !== 0 || res.data?.length < 1) return;let projectList = res.data;for (let i = 0; i < projectList.length; i++) {const projectInfoRes = await this.$api.projectService.BB({ projectCode: res.data[i].projectCode });if (projectInfoRes.code === 0 && projectInfoRes.data && projectInfoRes.data?.records.length > 0) {projectList[i] = { ...projectList[i], ...projectInfoRes.data.records[0] };if (projectList[i].projectStatus) {projectList[i].statusLabel = PROJECT_STATUS_MAP.find(item => item.value === projectList[i].projectStatus)?.label || projectList[i].projectStatus;projectList[i].statusColor = PROJECT_STATUS_MAP.find(item => item.value === projectList[i].projectStatus)?.color || '';const projectRes = await this.$api.projectService.CC({ projectCode: res.data[i].projectCode, projectStatus: projectList[i]?.projectStatus });if (projectRes.code === 0) {projectList[i].info = projectRes.data;}}}}this.projectList = projectList;} catch (error) {console.log(error);}this.loading = false;}

3. 解决方案

3.1 第一阶段:职责分离与并行优化(方案一)

优化目标

  • 解耦请求依赖
  • 提升并行度
  • 统一错误处理
  1. 将progress请求改为使用details中的状态参数
  2. 在数据合并阶段提前处理状态信息
  3. 保持每个方法的单一职责:
    • fetchProjectProgress:专注处理带参数的API请求
    • mergeProjectData:负责数据合并和状态处理调度
    • processProjectStatus:专注状态转换逻辑
  4. 保持并行处理项目级别的请求,串行处理单个项目的依赖请求
  5. 使用更清晰的函数命名提升代码可读性
  6. 移除不必要的 console.log 改用 console.error 处理错误
    async loadProjectData() {this.loading = true;try {const baseList = await this.fetchBaseProjects();if (!baseList) return;// 并行处理const processedList = await Promise.all(baseList.map(async (item) => {const details = await this.fetchProjectDetails(item.projectCode);const progress = await this.fetchProjectProgress(item.projectCode,details?.projectStatus);return this.mergeProjectData(item, details, progress);}));this.projectList = processedList;} catch (error) {console.error('项目加载失败:', error);} finally {this.loading = false;}},async fetchBaseProjects() {const res = await this.$api.projectService.AA({ clientId: this.customer.clientId });return res.code === 0 && res.data?.length ? res.data : null;},async fetchProjectDetails(projectCode) {const res = await this.$api.projectService.BB({ projectCode });return res.code === 0 && res.data?.records.length ? res.data.records[0] : null;},async fetchProjectProgress(projectCode, projectStatus) {const res = await this.$api.projectService.CC({ projectCode, projectStatus });return res.code === 0 ? res.data : null;},// 数据合并处理mergeProjectData(baseItem, details, progress) {const merged = { ...baseItem };if (details) Object.assign(merged, details);this.processProjectStatus(merged);  // 提前处理状态if (progress) merged.info = progress;return merged;},// 状态处理逻辑processProjectStatus(project) {if (project.projectStatus) {const status = PROJECT_STATUS_MAP.find(item => item.value === project.projectStatus);project.statusLabel = status?.label || project.projectStatus;project.statusColor = status?.color || '';}}

3.2 第二阶段:并行最大化(方案二)

优化目标

  • 消除串行请求
  • 缓存高频查询
  • 减少DOM操作
时间复杂度 O(n * (k + m))- n = 项目数量
- k = B 接口响应时间 
- m = C 接口响应时间
(当前串行执行导致总时间线性增长)空间复杂度 O(n)- 与项目数量成线性关系,主要存储 projectList 数据
    async loadProjectData() {this.loading = true;try {// 优化点1:使用缓存基准数据const baseRes = await this.$api.projectService.AA({ clientId: this.customer.clientId });if (baseRes.code !== 0 || !baseRes.data?.length) return;// 优化点2:并行处理请求const projectPromises = baseRes.data.map(async (baseItem) => {try {// 优化点3:并行请求子接口const [detailRes, progressRes] = await Promise.all([this.$api.projectService.BB({ projectCode: baseItem.projectCode }),this.$api.projectService.CC({projectCode: baseItem.projectCode,projectStatus: baseItem.projectStatus // 假设基准数据包含状态})]);// 优化点4:使用对象解构提升合并效率return {...baseItem,...(detailRes.data?.records[0] || {}),info: progressRes.data || null,statusLabel: this.getStatusLabel(baseItem.projectStatus),statusColor: this.getStatusColor(baseItem.projectStatus)};} catch (error) {console.error('子请求失败:', error);return baseItem; // 保持基础数据}});// 优化点5:批量更新数据this.projectList = await Promise.all(projectPromises);} catch (error) {console.error('主请求失败:', error);} finally {this.loading = false;}},// 新增状态映射方法getStatusLabel(status) {return PROJECT_STATUS_MAP.find(item => item.value === status)?.label || status;},getStatusColor(status) {return PROJECT_STATUS_MAP.find(item => item.value === status)?.color || '';}
优化点原方案新方案提升幅度
接口调用方式串行执行完全并行50%+
状态查询效率O(n) 遍历查找O(1) 缓存查询300%
数据合并方式多次对象赋值单次解构赋值40%
错误处理机制全流程中断子请求容错100%
DOM 更新次数多次更新单次批量更新60%

3.3 第三阶段:稳定性加固(方案三)

 async loadProjectData() {this.loading = true;try {const baseRes = await this.$api.projectService.AA({ clientId: this.customer.clientId });if (baseRes.code !== 0 || !baseRes.data?.length) return;// 使用 allSettled 保证部分失败不影响整体const settledResults = await Promise.allSettled(baseRes.data.map(async (baseItem) => {try {// 先获取必要详情数据const detailRes = await this.$api.projectService.BB({ projectCode: baseItem.projectCode });// 从详情响应中获取最新状态const currentStatus = detailRes.data?.records[0]?.projectStatus;// 并行获取其他数据const [progressRes] = await Promise.all([this.$api.projectService.CC({projectCode: baseItem.projectCode,// 使用最新状态,降级逻辑保障基础功能projectStatus: currentStatus || baseItem.projectStatus })]);return {...baseItem,...(detailRes.data?.records[0] || {}),info: progressRes.data || null,statusLabel: this.getStatusLabel(currentStatus),statusColor: this.getStatusColor(currentStatus)};} catch (error) {console.error('子请求失败:', error);return { ...baseItem, _error: true }; // 标记错误项}}));// 过滤处理成功的数据this.projectList = settledResults.filter(result => result.status === 'fulfilled' && !result.value._error).map(result => result.value);} catch (error) {console.error('主请求失败:', error);} finally {this.loading = false;}},// 新增状态映射方法getStatusLabel(status) {return PROJECT_STATUS_MAP.find(item => item.value === status)?.label || status;},getStatusColor(status) {return PROJECT_STATUS_MAP.find(item => item.value === status)?.color || '';}

主要优化点:

  1. 状态获取优化:从 B 接口响应获取最新状态,仅当状态不存在时使用基准数据
  2. 分级错误处理:
  • 使用 Promise.allSettled 保证单个项目失败不影响整体
  • 添加错误标记 _error 过滤无效数据
  • 保留基准数据用于降级展示
  1. 请求顺序调整:
  • 先获取包含状态的详情数据
  • 基于最新状态请求进展数据
  • 保持项目级别的并行处理

优化后特性:

  • 状态数据时效性:✅ 使用最新接口返回的状态
  • 错误容忍度:✅ 单项目错误不影响整体列表
  • 降级展示:✅ 即使子接口全失败仍显示基础信息
原始方案最终方案提升幅度
总耗时12.8s2.1s83%
内存占用34MB28MB18%
错误恢复率0%92%-

4. 未来优化

  1. 请求合并:与后端协商批量查询接口
  2. 缓存策略:添加本地缓存过期机制
  3. 性能监控:接入APM系统进行实时监控
  4. Skeleton优化:增加数据加载占位动画

“文中代码已进行脱敏处理,关键路径和参数均为示例数据”


文章转载自:

http://5cIqNodH.jyfrz.cn
http://eUvpEpc2.jyfrz.cn
http://C3OFjWJW.jyfrz.cn
http://7TrPAMZP.jyfrz.cn
http://N7r3EvUH.jyfrz.cn
http://2VFCrBZz.jyfrz.cn
http://NNQwMxPL.jyfrz.cn
http://HhwnUuQM.jyfrz.cn
http://CQ1QsV5E.jyfrz.cn
http://NDMKtuKd.jyfrz.cn
http://JZiLcfSv.jyfrz.cn
http://cP1nxP6R.jyfrz.cn
http://ZE8gQNqs.jyfrz.cn
http://xg1HS0L4.jyfrz.cn
http://AnAmJtbP.jyfrz.cn
http://mg1ksjmj.jyfrz.cn
http://wiBitJoD.jyfrz.cn
http://KscowESa.jyfrz.cn
http://mwkI3hmd.jyfrz.cn
http://0fzaJ2Ur.jyfrz.cn
http://flgKOGpm.jyfrz.cn
http://yqOKlqxt.jyfrz.cn
http://Z3kZ6bzu.jyfrz.cn
http://L9esUNBy.jyfrz.cn
http://4ejok9lX.jyfrz.cn
http://tyGAzV8M.jyfrz.cn
http://jgQlwecL.jyfrz.cn
http://KlmZQm8j.jyfrz.cn
http://81y0VBUO.jyfrz.cn
http://UZ8HzGN6.jyfrz.cn
http://www.dtcms.com/wzjs/628222.html

相关文章:

  • 绵阳网站建设策划内容网站建设 东阿阿胶
  • 优秀的定制网站建设制作商inove wordpress
  • 如何推广一个网站内江网站建设新闻
  • 网站后台管理系统后缀深圳软牛科技有限公司
  • 基于5G的网站设计网站关键词优化排名要怎么做
  • 杭州网站建设开发有限公司wordpress主题代码高亮
  • wordpress界面编排seo岗位工作内容
  • 网站不让百度收录基于wordpress门户网站
  • DW做旅游网站毕业设计长春网站建设小程序
  • 深夜小网站wordpress 域名迁移
  • 报社网站开发做什么wordpress 如何设置首页
  • 渭南做网站做文案策划需要用到的网站
  • 中文儿童网站模板帝国cms 做网站地图
  • 欧阳网站建设介休网站建设
  • 长沙php网站建设wordpress适合
  • 简约 网站株洲头条新闻
  • 成都建立网站的公司网站服装图案素材网站
  • 网站建设以及网页设计需要会什么中国建筑英才网
  • 陕西网站建设中英文网站是咋做的
  • 青岛建设局网站爱站网是干嘛的
  • 土地流转网站建设项目国家企业信息网官网查询营业执照
  • 企业网站建设的原则全国物流网站有哪些平台
  • 代运营网站app推广营销公司
  • 自己网站做虚拟币违法吗昆山建设招投标网站
  • 福建住房和城乡建设网站廊坊视频优化排名
  • 淘客网站怎么做代理魔方优化大师官网下载
  • 织梦做淘宝客网站重庆网站建设mswzjs
  • 重庆自助建站系统哪家好绵阳市建设工程质量监督站网站
  • 个人网站建设论文自适应企业网站源码
  • 营销型网站建设网站建设制作单页网站 营销