0

0

如何在结果页正确调用 displayScore 函数显示测验得分

碧海醫心

碧海醫心

发布时间:2026-01-21 13:02:18

|

288人浏览过

|

来源于php中文网

原创

如何在结果页正确调用 displayScore 函数显示测验得分

本文详解为何 results.html 中调用 displayscore() 报错“not defined”,并提供标准解决方案:确保 quiz.js 在函数调用前加载,同时给出健壮、可维护的交叉页面状态传递替代方案(不依赖 localstorage)。

在构建多页前端测验应用时,一个常见却易被初学者忽略的关键问题是:JavaScript 执行顺序与脚本加载时机。你遇到的 displayScore is not defined 错误,并非函数本身写错,而是浏览器在执行 <script>displayScore();</script> 时,quiz.js 尚未加载完成,导致 displayScore 函数在全局作用域中不可见。

? 根本原因分析

观察你的 results.html 片段:

<body>
  <p>Your score is: <span id="score"></span></p>
  <script>displayScore();</script> <!-- ❌ 此时 quiz.js 还没加载! -->
  <script src="quiz.js"></script>  <!-- ✅ 定义 displayScore 的地方 -->
</body>

浏览器按 HTML 中 <script> 标签出现的自上而下顺序解析和执行脚本。因此,displayScore() 被调用时,quiz.js 内容尚未注入,函数自然未定义。

✅ 正确做法:调整脚本加载顺序

只需交换两行 <script> 的位置即可修复:

<body>
  <p>Your score is: <span id="score"></span></p>
  <script src="quiz.js"></script>  <!-- ✅ 先加载,定义函数 -->
  <script>displayScore();</script> <!-- ✅ 再调用,此时函数已存在 -->
</body>
⚠️ 注意:<script> 默认是同步阻塞的,因此上述顺序能 100% 保证函数可用。无需 defer 或 async —— 它们反而可能破坏执行时序。

?️ 进阶建议:避免跨页状态丢失(无 localStorage)

你明确要求「不使用 localStorage」,但当前架构(每个问题页独立 HTML + 全局 quizQuestions 修改)存在严重隐患:当用户从 Q1.html 跳转到 Q2.html 时,前一页的 JavaScript 上下文完全销毁,quizQuestions 状态丢失。这意味着即使 displayScore 能运行,它看到的也仅是当前页(如 Q5.html)单独记录的对错,而非全部 5 题的累计结果。

Cursor
Cursor

一个新的IDE,使用AI来帮助您重构、理解、调试和编写代码。

下载

推荐轻量级替代方案:URL 参数传递

  1. 在每页“Next”按钮中,将当前题号和判断结果编码进 URL(例如 Q2.html?correct=1&score=1);
  2. 最终页 results.html 解析 URL 参数,汇总得分与各题正误
  3. 完全规避全局变量跨页失效问题,且不依赖任何存储 API

示例(简化版):

// 在 quiz.js 中添加工具函数
function getQueryParam(param) {
  return new URLSearchParams(window.location.search).get(param);
}

function displayScoreFromParams() {
  const total = 5;
  let score = 0;
  const results = [];

  for (let i = 0; i < total; i++) {
    const isCorrect = getQueryParam(`q${i}`) === '1';
    results.push({ q: i+1, correct: isCorrect });
    if (isCorrect) score++;
  }

  document.getElementById('score').textContent = score;

  // 渲染详细结果(可选)
  const detailEl = document.getElementById('detailed-results');
  detailEl.innerHTML = results.map(r => 
    `<p>Q${r.q}: ${r.correct ? '✅ Correct' : '❌ Incorrect'}</p>`
  ).join('');
}

然后在 results.html 中调用:

<body>
  <h2>Your Quiz Results</h2>
  <p>Your score is: <span id="score"></span>/5</p>
  <div id="detailed-results"></div>
  <script src="quiz.js"></script>
  <script>displayScoreFromParams();</script>
</body>

✅ 总结

  • 立即修复:把 <script src="quiz.js"> 移到所有调用它的 <script> 标签之前;
  • 长期健壮性:放弃依赖跨页全局变量,改用 URL 参数传递状态,符合无存储约束且逻辑清晰;
  • 额外提示:为防止用户直接访问 results.html 导致参数为空,可在 displayScoreFromParams() 中添加默认值或跳转校验。

遵循以上步骤,你不仅能解决当前报错,更能构建出可扩展、易调试的多页测验系统。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
全局变量怎么定义
全局变量怎么定义

本专题整合了全局变量相关内容,阅读专题下面的文章了解更多详细内容。

95

2025.09.18

python 全局变量
python 全局变量

本专题整合了python中全局变量定义相关教程,阅读专题下面的文章了解更多详细内容。

106

2025.09.18

js正则表达式
js正则表达式

php中文网为大家提供各种js正则表达式语法大全以及各种js正则表达式使用的方法,还有更多js正则表达式的相关文章、相关下载、相关课程,供大家免费下载体验。

531

2023.06.20

js获取当前时间
js获取当前时间

JS全称JavaScript,是一种具有函数优先的轻量级,解释型或即时编译型的编程语言;它是一种属于网络的高级脚本语言,主要用于Web,常用来为网页添加各式各样的动态功能。js怎么获取当前时间呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

576

2023.07.28

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

761

2023.08.03

js是什么意思
js是什么意思

JS是JavaScript的缩写,它是一种广泛应用于网页开发的脚本语言。JavaScript是一种解释性的、基于对象和事件驱动的编程语言,通常用于为网页增加交互性和动态性。它可以在网页上实现复杂的功能和效果,如表单验证、页面元素操作、动画效果、数据交互等。

6258

2023.08.17

js删除节点的方法
js删除节点的方法

js删除节点的方法有:1、removeChild()方法,用于从父节点中移除指定的子节点,它需要两个参数,第一个参数是要删除的子节点,第二个参数是父节点;2、parentNode.removeChild()方法,可以直接通过父节点调用来删除子节点;3、remove()方法,可以直接删除节点,而无需指定父节点;4、innerHTML属性,用于删除节点的内容。

492

2023.09.01

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

221

2023.09.04

TypeScript类型系统进阶与大型前端项目实践
TypeScript类型系统进阶与大型前端项目实践

本专题围绕 TypeScript 在大型前端项目中的应用展开,深入讲解类型系统设计与工程化开发方法。内容包括泛型与高级类型、类型推断机制、声明文件编写、模块化结构设计以及代码规范管理。通过真实项目案例分析,帮助开发者构建类型安全、结构清晰、易维护的前端工程体系,提高团队协作效率与代码质量。

26

2026.03.13

热门下载

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

精品课程

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

共58课时 | 6.1万人学习

TypeScript 教程
TypeScript 教程

共19课时 | 3.4万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.6万人学习

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

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