html做一个雷达图的软件

要实现一个在线输入数据并生成雷达图的功能,可以使用HTML表单和JavaScript来处理用户输入的数据。以下是一个示例代码,演示了如何实现这个功能:

html 复制代码
<!DOCTYPE html>
<html lang="zh">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>雷达图示例</title>
    <script src="https://cdn.jsdelivr.net/npm/chart.js"></script>
</head>
<body>
    <h2>输入数据生成雷达图</h2>
    <form id="dataForm">
        <label for="label1">标签1:</label>
        <input type="text" id="label1" name="label1" value="指标1"><br><br>
        <label for="value1">值1:</label>
        <input type="number" id="value1" name="value1" value="65"><br><br>

        <label for="label2">标签2:</label>
        <input type="text" id="label2" name="label2" value="指标2"><br><br>
        <label for="value2">值2:</label>
        <input type="number" id="value2" name="value2" value="59"><br><br>

        <label for="label3">标签3:</label>
        <input type="text" id="label3" name="label3" value="指标3"><br><br>
        <label for="value3">值3:</label>
        <input type="number" id="value3" name="value3" value="90"><br><br>

        <label for="label4">标签4:</label>
        <input type="text" id="label4" name="label4" value="指标4"><br><br>
        <label for="value4">值4:</label>
        <input type="number" id="value4" name="value4" value="81"><br><br>

        <label for="label5">标签5:</label>
        <input type="text" id="label5" name="label5" value="指标5"><br><br>
        <label for="value5">值5:</label>
        <input type="number" id="value5" name="value5" value="56"><br><br>

        <label for="label6">标签6:</label>
        <input type="text" id="label6" name="label6" value="指标6"><br><br>
        <label for="value6">值6:</label>
        <input type="number" id="value6" name="value6" value="55"><br><br>

        <button type="button" onclick="generateRadarChart()">生成雷达图</button>
    </form>

    <div style="width: 600px; height: 600px;">
        <canvas id="myRadarChart"></canvas>
    </div>

    <script>
        function generateRadarChart() {
            var labels = [];
            var data = [];

            for (var i = 1; i <= 6; i++) {
                labels.push(document.getElementById('label' + i).value);
                data.push(document.getElementById('value' + i).value);
            }

            var ctx = document.getElementById('myRadarChart').getContext('2d');
            if (window.myRadarChart instanceof Chart) {
                window.myRadarChart.destroy();
            }
            window.myRadarChart = new Chart(ctx, {
                type: 'radar',
                data: {
                    labels: labels,
                    datasets: [{
                        label: '数据集1',
                        data: data,
                        backgroundColor: 'rgba(255, 99, 132, 0.2)',
                        borderColor: 'rgba(255, 99, 132, 1)',
                        borderWidth: 1
                    }]
                },
                options: {
                    scale: {
                        ticks: {
                            beginAtZero: true
                        }
                    }
                }
            });
        }
    </script>
</body>
</html>

解释

  1. 表单部分:我们使用HTML表单来获取用户的输入数据。每个标签和值都有一个输入框,用户可以在这些输入框中输入数据。

  2. 生成雷达图按钮 :点击"生成雷达图"按钮时,会调用JavaScript函数generateRadarChart()

  3. JavaScript函数generateRadarChart()函数从表单中获取用户输入的标签和值,并将其存储在数组中。然后,它使用这些数据创建或更新雷达图。如果图表已经存在,它将销毁旧的图表并创建新的图表。

  4. 图表部分:使用Canvas元素来容纳雷达图,并使用Chart.js库来创建图表。

通过这种方式,你可以在网页上输入数据并动态生成雷达图。用户可以通过输入不同的数据来实时查看雷达图的变化。

相关推荐
百***24378 分钟前
Grok-4.1 API进阶实战:Python项目集成、性能优化与异常处理全攻略
python·spring·性能优化
Trust yourself24310 分钟前
魔塔社区下载的大模型如何通过ollama部署到本地
python
码农胖虎-java11 分钟前
【java并发编程】从源码角度彻底理解 ForkJoinPool.commonPool
java·开发语言·python
CQ_YM13 分钟前
SQLite3 数据库与网页html
c语言·数据库·sqlite·html
毕设源码-朱学姐14 分钟前
【开题答辩全过程】以 基于Python淘宝电脑销售数据可视化系为例,包含答辩的问题和答案
python·信息可视化·电脑
爱说实话15 分钟前
c# 20260113
开发语言·c#
三木彤16 分钟前
Scikit-learn 零基础,从安装到实战机器学习模型
python
小郭团队16 分钟前
1_2_五段式SVPWM (传统算法反正切+DPWMmin)算法理论与 MATLAB 实现详解
开发语言·嵌入式硬件·matlab·dsp开发
Ulyanov17 分钟前
高级可视化技术——让PyVista数据展示更专业
开发语言·前端·人工智能·python·tkinter·gui开发
开开心心_Every19 分钟前
重复图片智能清理工具:快速查重批量删除
java·服务器·开发语言·前端·学习·edge·powerpoint