html做一个画热图的软件

完整示例

html 复制代码
<!DOCTYPE html>
<html lang="zh-CN">
<head>
    <meta charset="UTF-8">
    <title>热图生成器</title>
    <script src="https://cdn.plot.ly/plotly-latest.min.js"></script>
    <style>
        body {
            font-family: Arial, sans-serif;
        }
        #inputContainer {
            margin-bottom: 20px;
        }
        textarea {
            width: 100%;
            height: 100px;
        }
        button {
            margin-top: 10px;
        }
        #heatmap {
            width: 100%;
            height: 500px;
        }
    </style>
</head>
<body>
    <h1>热图生成器</h1>
    <div id="inputContainer">
        <label for="dataInput">请输入数据(以逗号分隔,每行表示一行数据):</label>
        <textarea id="dataInput">1,20,30\n20,1,60\n30,60,1</textarea>
        <br>
        <button onclick="generateHeatmap()">生成热图</button>
    </div>
    <div id="heatmap"></div>

    <script>
        function generateHeatmap() {
            // 获取输入的数据
            const inputData = document.getElementById('dataInput').value;
            
            // 解析数据
            const rows = inputData.split('\n');
            const z = rows.map(row => row.split(',').map(Number));

            // 定义热图数据
            const data = [
                {
                    z: z,
                    type: 'heatmap'
                }
            ];

            const layout = {
                title: '生成的热图',
                xaxis: {
                    title: '列'
                },
                yaxis: {
                    title: '行'
                }
            };

            // 绘制热图
            Plotly.newPlot('heatmap', data, layout);
        }
    </script>
</body>
</html>

说明

  1. 引入Plotly.js库 :在<head>标签中,通过<script>标签引入Plotly.js库。
  2. 输入数据的文本区域 :在<div id="inputContainer">中添加一个<textarea>供用户输入数据。
  3. 生成热图的按钮 :添加一个按钮,点击按钮时会调用generateHeatmap函数。
  4. 生成热图的函数
    • <textarea>中获取用户输入的数据。
    • 将输入的数据按行拆分,并将每行数据按逗号拆分成数组。
    • 使用这些数据生成热图。
    • 使用Plotly.js的Plotly.newPlot函数将热图绘制到<div id="heatmap">中。

使用方法

  1. 将上述代码保存为一个HTML文件(例如heatmap_generator.html)。

  2. 在浏览器中打开该文件。

  3. 在文本区域中输入数据,每行代表一行数据,数据项之间用逗号分隔。例如:

    1,20,30
    20,1,60
    30,60,1
    
  4. 点击"生成热图"按钮,热图将会显示在页面中。

相关推荐
Simaoya8 分钟前
vue判断元素滚动到底部后加载更多
前端·javascript·vue.js
头顶一只喵喵9 分钟前
Vue基础知识:Vue3.3出现的defineOptions,如何使用,解决了什么问题?
前端·javascript·vue.js·vue3
懒大王爱吃狼22 分钟前
【Python自动化】Python实现微信自动回复(简单上手),60行代码轻松搞定!个性化自动回复机器人,零基础可学!
运维·开发语言·python·数据分析·自动化·学习方法
黑色的糖果42 分钟前
echarts横向立体3D柱状图
前端·javascript·echarts
茶卡盐佑星_1 小时前
vue3.0所采用的composition Api与vue2.x使用的Option Api有什么区别
前端·javascript·vue.js
乐安lan1 小时前
01前端导入
前端
lauo1 小时前
【WEB前端2024】3D智体编程:乔布斯3D纪念馆-第55课-芝麻开门(语音 识别 控制3D纪念馆开门 和 关门)
前端·javascript·人工智能·3d·机器人·开源·语音识别
2401_857622661 小时前
探索 WebKit 的动感世界:设备方向和运动支持全解析
前端·webkit
开源博客1 小时前
Vue3 如何接入 i18n 实现国际化多语言
前端·vue·i18n·vite
Ann_R1 小时前
el-date-picker 开始时间选定后,结束时间不可选择开始时间之前的日期
前端·vue.js·elementui