最丑王子 2023-08-15 16:48 采纳率: 50%
浏览 10
已结题

在springboot项目前端遇到websocket无法更新最新数据渲染问题

在springboot项目前端遇到websocket无法更新最新数据渲染问题

<!DOCTYPE html>
<html>
<head>
    <title>WebSocket Example</title>
</head>
<body>

<!-- 表格一 -->
<table class="table table-bordered">
    <thead>
    <tr>
        <th>公司名称</th>
        <th>当前价格</th>
    </tr>
    </thead>
    <tbody id="company-table-body">
    </tbody>
</table>

<!-- 表格二 -->
<table class="table table-bordered">
    <thead>
    <tr>
        <th>ID</th>
        <th>买入金额</th>
        <th>买入数量</th>
    </tr>
    </thead>
    <tbody id="buy-orders-table-body">
    </tbody>
</table>

<!-- 表格三 -->
<table class="table table-bordered">
    <thead>
    <tr>
        <th>ID</th>
        <th>卖出金额</th>
        <th>卖出数量</th>
    </tr>
    </thead>
    <tbody id="sell-orders-table-body">
    </tbody>
</table>

<script>
    // 保存当前数据的变量
    let shareCapitalList = [];
    let buyOrdersList = [];
    let sellOrdersList = [];

    const ws = new WebSocket("ws://localhost:8081/websocket");

    ws.onopen = function() {
        console.log('WebSocket connected');
    }

    ws.onmessage = function(event) {
        console.log(event.data);
        if (event.data.startsWith("shareCapitalList:")) {
            shareCapitalList = JSON.parse(event.data.substring(17));
            renderCompanyTable(shareCapitalList);
        } else if (event.data.startsWith("buyOrdersList:")) {
            buyOrdersList = JSON.parse(event.data.substring(14));
            renderBuyOrdersTable(buyOrdersList);
        } else if (event.data.startsWith("sellOrdersList:")) {
            sellOrdersList = JSON.parse(event.data.substring(15));
            renderSellOrdersTable(sellOrdersList);
        }
    }


    ws.onclose = function() {
        console.log('WebSocket disconnected');
    }

    function renderTableData(data, tbodyId) {
        // 获取 tbody 元素
        const tbody = document.getElementById(tbodyId);

        // 清空之前的数据
        tbody.innerHTML = "";

        // 生成 HTML 代码
        const html = data.map((item) => {
            let rowHtml = "";
            for (const [key, value] of Object.entries(item)) {
                rowHtml += `<td>${value}</td>`;
            }
            return `<tr>${rowHtml}</tr>`;
        }).join("");

        // 更新表格数据
        tbody.innerHTML = html;
    }

    function renderCompanyTable(data) {
        // 渲染表格一数据
        renderTableData(data, "company-table-body");
    }

    function renderBuyOrdersTable(data) {
        // 渲染表格二数据
        renderTableData(data, "buy-orders-table-body");
    }

    function renderSellOrdersTable(data) {
        // 渲染表格三数据
        renderTableData(data, "sell-orders-table-body");
    }

</script>
</body>
</html>

初始化数据可以正常渲染如下图

img

但是websocket发布了新的数据时,前端无法正常渲染新的数据,还是最初的数据如下图

img

我想要前端可以正常自动渲染最新的数据

  • 写回答

2条回答 默认 最新

  • 雾里桃花 2023-08-15 16:58
    关注

    这几个判断通过了吗

    img

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 8月23日
  • 已采纳回答 8月15日
  • 创建了问题 8月15日

悬赏问题

  • ¥15 急,ubuntu安装后no caching mode page found等
  • ¥15 联想交换机NE2580O/NE1064TO安装SONIC
  • ¥15 防火墙的混合模式配置
  • ¥15 Ubuntu不小心注销了要怎么恢复啊
  • ¥15 win10电脑安装完plcsim advanced4.0运行时为什么会提示找不到虚拟网卡
  • ¥15 安装powerbuilder10卡在安装程序正在运行这个页面 没有下一步任何指令
  • ¥15 关于mpi的问题:请问遇到这种情况需要怎么解决,出现这个问题后电脑不能进行mpi多核运行只能进行单核运行
  • ¥50 微信聊天记录备份到电脑提示成功了,但还是没同步到电脑微信
  • ¥15 python怎么在已有视频文件后添加新帧
  • ¥20 虚幻UE引擎如何让多个同一个蓝图的NPC执行一样的动画,