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

在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日