使用 JavaScript 构建游戏分析仪表板
zhezhongyun 2025-07-06 18:00 31 浏览
今天,我们将用 JavaScript 创建一个游戏分析仪表盘。
本文旨在快速介绍,因此最好具有 JavaScript、HTML 和 CSS 方面的经验。
但为什么我们需要游戏分析仪表盘
要用数据赋能您的服务,首先需要分析玩家行为和游戏数据。这样,您就可以改进游戏玩法、增强游戏机制,甚至全面升级您的游戏。
你还可以追踪玩家数量,削弱你的阿卡丽直到她成为小兵等等。事实上,游戏数据可以做很多事情。
为了有效地分析这些游戏数据,首先需要将其收集并存储在某个地方,以便更快地进行分析。因此,游戏分析仪表盘正是为此而生的。
示例数据
但是,对于这个项目,我们不会有一个已经构建的游戏来提供数据或数据管道来向我们的仪表板提供信息。
相反,我们将创建 JSON 格式的示例数据以在我们的仪表板中使用。
我们可以编写一个包含 44 个(我喜欢数字 4)玩家会话的数组,其中将包含一个 ID(类似于您的 Hoyoverse ID)、一个分数以及每个玩家在游戏中会话的持续时间。
function generatePlayerData(id) {
return {
id: id,
score: Math.floor(Math.random() * 1000),
duration: (Math.floor(Math.random() * 86400) / 3600).toFixed(2)
};
}
const playerSessions = [];
for (let i = 1; i <= 44; i++) {
playerSessions.push(generatePlayerData(`Player ${i}`));
}
console.log(playerSessions); [
{ Id: 'Player 1', Score: 592, Duration: '3.67' },
{ Id: 'Player 2', Score: 879, Duration: '16.45' },
{ Id: 'Player 3', Score: 116, Duration: '8.59' },
{ Id: 'Player 4', Score: 736, Duration: '0.47' },
{ Id: 'Player 5', Score: 301, Duration: '6.03' },
{ Id: 'Player 6', Score: 116, Duration: '12.01' },
{ Id: 'Player 7', Score: 371, Duration: '9.96' },
{ Id: 'Player 8', Score: 466, Duration: '15.23' },
{ Id: 'Player 9', Score: 186, Duration: '21.66' },
{ Id: 'Player 10', Score: 279, Duration: '2.05' },
]处理数据
让我们把数据变得重要起来,向其他人展示。由于手头数据不多,我们可以决定一些基本流程:平均游戏时长、玩家平均得分,以及按得分确定前十名玩家。
const totalDuration = playerSessions.reduce((sum, session) => sum + parseFloat(session.duration), 0);
const avgDuration = (totalDuration / playerSessions.length).toFixed(2);
const totalScore = playerSessions.reduce((sum, session) => sum + session.score, 0);
const avgScore = (totalScore / playerSessions.length).toFixed(2);
const topPlayers = playerSessions
.slice()
.sort((a, b) => b.score - a.score)
.slice(0, 10);// For stats overview box
document.getElementById('stats').innerHTML = `
<h2>Stats Overview</h2>
<p><strong>Average Duration:</strong> ${avgDuration} hours</p>
<p><strong>Average Score:</strong> ${avgScore}</p>
`;最后,我们有了可以展示给管理层的重要数据。让我们从一些酷炫的图表和排行榜开始。
在浏览器中可视化数据
让我们从简单的开始,不做任何定制,只使用纯粹的图表和表格。本文中的图表我们将使用 Chart.js。
const ctx = document.getElementById('scoreChart').getContext('2d');
// Make a bar chart for player scores
const scoreChart = new Chart(ctx, {
type: 'bar',
data: {
// labels for x-axis = all player IDs
labels: playerSessions.map(s => s.id),
datasets: [{
label: 'Scores',
data: playerSessions.map(s => s.score),
backgroundColor: 'rgba(75, 192, 192, 0.2)',
borderColor: 'rgba(75, 192, 192, 1)',
borderWidth: 1
}]
},
options: {
scales: { y: { beginAtZero: true } } // y-axis always starts at zero (makes sense for scores)
}
});
const leaderboardDiv = document.getElementById('leaderboard');
leaderboardDiv.innerHTML = '<h2>Leaderboard</h2>';
// Show top players in leaderboard div
topPlayers.forEach((player, i) => {
leaderboardDiv.innerHTML += `<p>${i + 1}. ${player.id} - Score: ${player.score}</p>`;
});
// Stats box update
document.getElementById('stats').innerHTML = `
<h2>Stats Overview</h2>
<p><strong>Average Duration:</strong> ${avgDuration} hours</p>
<p><strong>Average Score:</strong> ${avgScore}</p>
`;
现在我们已经介绍了基础知识,让我们继续讨论 HTML 文件:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Player Dashboard</title>
<script src="https://cdn.jsdelivr.net/npm/chart.js"></script>
</head>
<body>
<div class="dashboard-container">
<header><h1>Game Analytics Dashboard</h1></header>
<div id="stats" class="card"></div>
<div class="main-content">
<canvas id="scoreChart"></canvas>
<div id="leaderboard" class="card leaderboard"></div>
</div>
</div>
<script src="main.js"></script>
</body>
</html>现在你应该看到类似这样的内容:
简单的仪表板
尚未定制,只是纯白房间中的原始数据。让我们用对比、优雅和一丝火焰赋予它生命。
接下来,我们将添加一个 style.css 文件并确保它在我们的 HTML 中正确链接。
body {
margin: 0;
font-family: 'Segoe UI', sans-serif;
background-color: #ffffff;
color: #111111;
}
header {
text-align: center;
padding: 1.5rem 0;
color: #000000;
font-size: 2rem;
font-weight: bold;
letter-spacing: 1px;
}
.dashboard-container {
max-width: 1200px;
margin: 0 auto;
padding: 2rem;
}
.main-content {
display: flex;
gap: 3rem;
flex-wrap: wrap;
justify-content: space-between;
align-items: flex-start;
margin-top: 1rem;
}
canvas {
flex: 2;
max-width: 700px;
background-color: #fafafa;
border-radius: 12px;
padding: 1.5rem;
box-shadow: 0 4px 12px rgba(0, 0, 0, 0.05);
}
.card {
background-color: #fff;
padding: 2rem;
border-radius: 12px;
border: 1px solid #e0e0e0;
box-shadow: 0 4px 12px rgba(0, 0, 0, 0.05);
}
.leaderboard {
flex: 1;
min-width: 280px;
}
.leaderboard-entry {
display: flex;
justify-content: space-between;
padding: 0.6rem 0;
border-bottom: 1px solid #eee;
}
.rank {
font-weight: bold;
color: #ff2a2a;
}
.player-name {
flex: 1;
margin-left: 1rem;
color: #111111;
}
.player-score {
font-weight: bold;
color: #111111;
}
h2 {
color: #000000;
border-bottom: 2px solid #ff2a2a;
padding-bottom: 0.5rem;
margin-bottom: 1.5rem;
}<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Player Dashboard</title>
<link rel="stylesheet" href="style.css">
<script src="https://cdn.jsdelivr.net/npm/chart.js"></script>
</head>
<body>
<div class="dashboard-container">
<header><h1>Game Analytics Dashboard</h1></header>
<div id="stats" class="card"></div>
<div class="main-content">
<canvas id="scoreChart"></canvas>
<div id="leaderboard" class="card leaderboard"></div>
</div>
</div>
<script src="main.js"></script>
</body>
</html>管理员的最终仪表板
现在我们有了一个真正可以称为仪表板的仪表板。
使用 Chart.js 生成实时图表非常简单,如果您已经了解 JavaScript、HTML 和 CSS,则不需要任何额外的技能。
结论
仪表板很酷,它们在一个地方显示您需要的所有内容,并且您的数据值得用漂亮的仪表板来呈现。
使用仪表板可以更轻松地呈现数据,并且借助 JavaScript Chart.js 库,您可以在呈现时进行实时更新。
您可以轻松自定义仪表板样式,并使用简单的 JSON 格式更新数据。此外,您还可以轻松创建自己的仪表板。
本文旨在帮助您入门,仅此而已。完整代码地址。
本文为译文,英文原文地址(可能需要使用魔法访问或付费会员才可观看):
https://ryuru.com/building-game-analytics-dashboard-with-javascript/
相关推荐
- Python入门学习记录之一:变量_python怎么用变量
-
写这个,主要是对自己学习python知识的一个总结,也是加深自己的印象。变量(英文:variable),也叫标识符。在python中,变量的命名规则有以下三点:>变量名只能包含字母、数字和下划线...
- python变量命名规则——来自小白的总结
-
python是一个动态编译类编程语言,所以程序在运行前不需要如C语言的先行编译动作,因此也只有在程序运行过程中才能发现程序的问题。基于此,python的变量就有一定的命名规范。python作为当前热门...
- Python入门学习教程:第 2 章 变量与数据类型
-
2.1什么是变量?在编程中,变量就像一个存放数据的容器,它可以存储各种信息,并且这些信息可以被读取和修改。想象一下,变量就如同我们生活中的盒子,你可以把东西放进去,也可以随时拿出来看看,甚至可以换成...
- 绘制学术论文中的“三线表”具体指导
-
在科研过程中,大家用到最多的可能就是“三线表”。“三线表”,一般主要由三条横线构成,当然在变量名栏里也可以拆分单元格,出现更多的线。更重要的是,“三线表”也是一种数据记录规范,以“三线表”形式记录的数...
- Python基础语法知识--变量和数据类型
-
学习Python中的变量和数据类型至关重要,因为它们构成了Python编程的基石。以下是帮助您了解Python中的变量和数据类型的分步指南:1.变量:变量在Python中用于存储数据值。它们充...
- 一文搞懂 Python 中的所有标点符号
-
反引号`无任何作用。传说Python3中它被移除是因为和单引号字符'太相似。波浪号~(按位取反符号)~被称为取反或补码运算符。它放在我们想要取反的对象前面。如果放在一个整数n...
- Python变量类型和运算符_python中变量的含义
-
别再被小名词坑哭了:Python新手常犯的那些隐蔽错误,我用同事的真实bug拆给你看我记得有一次和同事张姐一起追查一个看似随机崩溃的脚本,最后发现罪魁祸首竟然是她把变量命名成了list。说实话...
- 从零开始:深入剖析 Spring Boot3 中配置文件的加载顺序
-
在当今的互联网软件开发领域,SpringBoot无疑是最为热门和广泛应用的框架之一。它以其强大的功能、便捷的开发体验,极大地提升了开发效率,成为众多开发者构建Web应用程序的首选。而在Spr...
- Python中下划线 ‘_’ 的用法,你知道几种
-
Python中下划线()是一个有特殊含义和用途的符号,它可以用来表示以下几种情况:1在解释器中,下划线(_)表示上一个表达式的值,可以用来进行快速计算或测试。例如:>>>2+...
- 解锁Shell编程:变量_shell $变量
-
引言:开启Shell编程大门Shell作为用户与Linux内核之间的桥梁,为我们提供了强大的命令行交互方式。它不仅能执行简单的文件操作、进程管理,还能通过编写脚本实现复杂的自动化任务。无论是...
- 一文学会Python的变量命名规则!_python的变量命名有哪些要求
-
目录1.变量的命名原则3.内置函数尽量不要做变量4.删除变量和垃圾回收机制5.结语1.变量的命名原则①由英文字母、_(下划线)、或中文开头②变量名称只能由英文字母、数字、下画线或中文字所组成。③英文字...
- 更可靠的Rust-语法篇-区分语句/表达式,略览if/loop/while/for
-
src/main.rs://函数定义fnadd(a:i32,b:i32)->i32{a+b//末尾表达式}fnmain(){leta:i3...
- C++第五课:变量的命名规则_c++中变量的命名规则
-
变量的命名不是想怎么起就怎么起的,而是有一套固定的规则的。具体规则:1.名字要合法:变量名必须是由字母、数字或下划线组成。例如:a,a1,a_1。2.开头不能是数字。例如:可以a1,但不能起1a。3....
- Rust编程-核心篇-不安全编程_rust安全性
-
Unsafe的必要性Rust的所有权系统和类型系统为我们提供了强大的安全保障,但在某些情况下,我们需要突破这些限制来:与C代码交互实现底层系统编程优化性能关键代码实现某些编译器无法验证的安全操作Rus...
- 探秘 Python 内存管理:背后的神奇机制
-
在编程的世界里,内存管理就如同幕后的精密操控者,确保程序的高效运行。Python作为一种广泛使用的编程语言,其内存管理机制既巧妙又复杂,为开发者们提供了便利的同时,也展现了强大的底层控制能力。一、P...
- 一周热门
- 最近发表
- 标签列表
-
- HTML 教程 (33)
- HTML 简介 (35)
- HTML 实例/测验 (32)
- HTML 测验 (32)
- JavaScript 和 HTML DOM 参考手册 (32)
- HTML 拓展阅读 (30)
- HTML文本框样式 (31)
- HTML滚动条样式 (34)
- HTML5 浏览器支持 (33)
- HTML5 新元素 (33)
- HTML5 WebSocket (30)
- HTML5 代码规范 (32)
- HTML5 标签 (717)
- HTML5 标签 (已废弃) (75)
- HTML5电子书 (32)
- HTML5开发工具 (34)
- HTML5小游戏源码 (34)
- HTML5模板下载 (30)
- HTTP 状态消息 (33)
- HTTP 方法:GET 对比 POST (33)
- 键盘快捷键 (35)
- 标签 (226)
- opacity 属性 (32)
- transition 属性 (33)
- 1-1. 变量声明 (31)
