0

0

实现Trivia游戏中按钮点击索引获取与答案校验

花韻仙語

花韻仙語

发布时间:2025-10-19 09:15:38

|

864人浏览过

|

来源于php中文网

原创

实现trivia游戏中按钮点击索引获取与答案校验

本文档旨在指导开发者如何在Trivia游戏中获取每个按钮的索引,并校验用户选择的答案是否正确。通过事件监听器和事件对象,我们可以轻松区分点击的按钮,进而与正确答案进行比较。本文将提供详细的代码示例和步骤,帮助你理解和实现这一功能。

获取按钮索引

在Trivia游戏中,区分用户点击的是哪个按钮至关重要。JavaScript的事件监听器提供了一个强大的工具来实现这一点:event对象。当一个事件发生时(例如,按钮被点击),事件监听器的回调函数会接收到一个event对象,该对象包含了关于该事件的各种信息,包括触发事件的元素。

以下代码展示了如何使用event.target属性来获取被点击按钮的ID:

const buttons = document.querySelectorAll(".btn");

buttons.forEach((btnEl) =>
  btnEl.addEventListener("click", (event) => {
    console.log('button clicked id -', event.target.id);
  })
);



在这个例子中,我们首先使用document.querySelectorAll(".btn")获取所有class为"btn"的按钮元素。然后,我们使用forEach循环遍历每个按钮,并为每个按钮添加一个点击事件监听器。当按钮被点击时,回调函数会被执行,event.target.id会返回被点击按钮的ID。

注意: 在实际生产环境中,不建议像上述代码示例那样为每个按钮单独添加事件监听器。更好的做法是利用事件冒泡(bubbling)或事件捕获(capturing)机制,将事件监听器添加到按钮的父元素上,然后通过event.target来判断是哪个按钮被点击。

校验答案

有了按钮的ID,我们就可以将其与正确答案进行比较。假设你已经有了一个包含问题和答案的对象数组,并且每个答案对象都有一个correct属性,表示该答案是否正确。

ONLYOFFICE
ONLYOFFICE

用ONLYOFFICE管理你的网络私人办公室

下载

以下是一个示例:

const questions = [
    {
        question: 'What year did the United State gain independence?',
        answers: [
          { text: '1776', correct: true },
          { text: '1876', correct: false },
          { text: '1676', correct: false },
          { text: '1576', correct: false }
        ]
      },
];

let randomQuestion = questions[Math.floor(Math.random()*questions.length)];

function checkAnswer(event) {
  const clickedButtonId = event.target.id;
  const answerIndex = clickedButtonId.split('-')[1]; // 假设ID格式为 "answer-1", "answer-2" 等

  const answer = randomQuestion.answers[answerIndex - 1]; // 数组索引从0开始

  if (answer.correct) {
    console.log("Correct!");
  } else {
    console.log("Incorrect!");
  }
}

const buttons = document.querySelectorAll(".btn");

buttons.forEach((btnEl) =>
  btnEl.addEventListener("click", checkAnswer)
);

在这个例子中,checkAnswer函数接收event对象作为参数。我们首先通过event.target.id获取被点击按钮的ID,然后从ID中提取答案的索引。接下来,我们使用该索引从randomQuestion.answers数组中获取对应的答案对象。最后,我们检查answer.correct属性,并根据结果输出"Correct!"或"Incorrect!"。

注意事项:

  • 确保按钮的ID格式是可预测的,例如 "answer-1", "answer-2" 等,这样你才能从中提取答案的索引。
  • 数组索引从0开始,因此你需要将从按钮ID中提取的索引减1。
  • 在实际应用中,你需要根据你的具体需求来修改代码。例如,你可能需要将结果显示在页面上,或者将结果发送到服务器。

总结

通过结合事件监听器和事件对象,我们可以轻松地获取Trivia游戏中被点击按钮的索引,并将其与正确答案进行比较。这为实现互动性强、用户体验良好的Trivia游戏提供了基础。记住,代码示例只是起点,你需要根据你的具体需求进行修改和扩展。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
php中foreach用法
php中foreach用法

本专题整合了php中foreach用法的相关介绍,阅读专题下面的文章了解更多详细教程。

75

2025.12.04

class在c语言中的意思
class在c语言中的意思

在C语言中,"class" 是一个关键字,用于定义一个类。想了解更多class的相关内容,可以阅读本专题下面的文章。

469

2024.01.03

python中class的含义
python中class的含义

本专题整合了python中class的相关内容,阅读专题下面的文章了解更多详细内容。

15

2025.12.06

clawdbot ai使用教程 保姆级clawdbot部署安装手册
clawdbot ai使用教程 保姆级clawdbot部署安装手册

Clawdbot是一个“有灵魂”的AI助手,可以帮用户清空收件箱、发送电子邮件、管理日历、办理航班值机等等,并且可以接入用户常用的任何聊天APP,所有的操作均可通过WhatsApp、Telegram等平台完成,用户只需通过对话,就能操控设备自动执行各类任务。

19

2026.01.29

clawdbot龙虾机器人官网入口 clawdbot ai官方网站地址
clawdbot龙虾机器人官网入口 clawdbot ai官方网站地址

clawdbot龙虾机器人官网入口:https://clawd.bot/,clawdbot ai是一个“有灵魂”的AI助手,可以帮用户清空收件箱、发送电子邮件、管理日历、办理航班值机等等,并且可以接入用户常用的任何聊天APP,所有的操作均可通过WhatsApp、Telegram等平台完成,用户只需通过对话,就能操控设备自动执行各类任务。

16

2026.01.29

Golang 网络安全与加密实战
Golang 网络安全与加密实战

本专题系统讲解 Golang 在网络安全与加密技术中的应用,包括对称加密与非对称加密(AES、RSA)、哈希与数字签名、JWT身份认证、SSL/TLS 安全通信、常见网络攻击防范(如SQL注入、XSS、CSRF)及其防护措施。通过实战案例,帮助学习者掌握 如何使用 Go 语言保障网络通信的安全性,保护用户数据与隐私。

8

2026.01.29

俄罗斯Yandex引擎入口
俄罗斯Yandex引擎入口

2026年俄罗斯Yandex搜索引擎最新入口汇总,涵盖免登录、多语言支持、无广告视频播放及本地化服务等核心功能。阅读专题下面的文章了解更多详细内容。

567

2026.01.28

包子漫画在线官方入口大全
包子漫画在线官方入口大全

本合集汇总了包子漫画2026最新官方在线观看入口,涵盖备用域名、正版无广告链接及多端适配地址,助你畅享12700+高清漫画资源。阅读专题下面的文章了解更多详细内容。

209

2026.01.28

ao3中文版官网地址大全
ao3中文版官网地址大全

AO3最新中文版官网入口合集,汇总2026年主站及国内优化镜像链接,支持简体中文界面、无广告阅读与多设备同步。阅读专题下面的文章了解更多详细内容。

350

2026.01.28

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
React 教程
React 教程

共58课时 | 4.3万人学习

TypeScript 教程
TypeScript 教程

共19课时 | 2.5万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.1万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号