首页 > web前端 > js教程 > 正文

Vue+ElementUI表格渲染延迟:如何解决异步请求导致的数据显示问题?

DDD
发布: 2025-03-23 08:08:28
原创
570人浏览过

vue+elementui表格渲染延迟:如何解决异步请求导致的数据显示问题?

Vue+ElementUI表格数据渲染延迟及优化策略

在Vue和ElementUI项目中,表格数据渲染延迟是一个常见问题。本文将分析一个案例,该案例中表格部分字段在页面加载时无法显示,只有在打开浏览器开发者工具后才显示。

问题描述:

一个使用el-table组件显示申请记录的页面,需要从后端获取申请人ID,再通过循环调用接口获取申请人姓名等信息,并动态添加到tableData中。页面加载后,申请人姓名等字段缺失,只有打开开发者工具后才显示。 原始代码如下:

立即学习前端免费学习笔记(深入)”;

async getdata() {
    await axios.get("http://localhost:10100/apply/getalloutapplypageofgroup", {
        params: {
            approvalid: localStorage.getItem("userid"),
            pn: this.currentpage,
            ps: this.pagesize
        }
    }).then(res => {
        this.tabledata = res.data.data.records
        this.total = res.data.data.total
    })

    for (var i in this.tabledata) {
        await axios.get("http://localhost:10100/user/getusername", {
            params: {
                userid: this.tabledata[i].applicantid
            }
        }).then(res => {
            this.tabledata[i].applicantname = res.data.data
        })

        // ... 其他异步请求 ...
    }
}
登录后复制

该代码在mounted生命周期中调用getdata方法。问题根源在于getdata函数中使用了大量的await关键字,导致同步循环,造成数据渲染延迟。打开开发者工具可能会意外触发Vue更新机制,从而显示数据。

解决方案:并发请求与Promise.all

避免同步循环和多次await,应优化代码,将异步请求改为并发请求,使用Promise.all等待所有请求完成后再更新数据。改进后的代码如下:

async getData() {
    const applyData = await axios.get("http://localhost:10100/Apply/getAllOutApplyPageOfGroup", {
        params: {
            approvalId: localStorage.getItem("userId"),
            pn: this.currentPage,
            ps: this.pageSize
        }
    });
    this.tableData = applyData.data.data.records;
    this.total = applyData.data.data.total;

    const promises = this.tableData.map(item => {
        return Promise.all([
            axios.get("http://localhost:10100/User/getUserName", { params: { userId: item.applicantId } }),
            axios.get("http://localhost:10100/Chemicals/getChemicalName", { params: { chemicalId: item.chemicalId } }),
            axios.get("http://localhost:10100/Chemicals/getUnit", { params: { chemicalId: item.chemicalId } })
        ]).then(([userNameRes, chemicalNameRes, unitRes]) => {
            item.applicantName = userNameRes.data.data;
            item.chemicalName = chemicalNameRes.data.data;
            item.unit = unitRes.data.data;
        });
    });

    await Promise.all(promises); // 等待所有请求完成
    this.$forceUpdate();//强制更新视图
}
登录后复制

通过Promise.all,并发执行多个异步请求,显著提升效率,解决数据显示延迟。 所有数据获取完成后再更新tableData,并使用this.$forceUpdate()强制更新视图,确保数据正确显示在el-table中。

记住在el-table中正确绑定tableData数据。 此优化策略有效避免了因异步操作导致的渲染延迟问题。

以上就是Vue+ElementUI表格渲染延迟:如何解决异步请求导致的数据显示问题?的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号