简单的MBTI测试的Web网页的HTML、CSS和JS代码,以及解析注释:

2023-10-15 01:04

本文主要是介绍简单的MBTI测试的Web网页的HTML、CSS和JS代码,以及解析注释:,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

这是一个简单的MBTI测试的Web网页的HTML、CSS和JS代码,以及解析注释:

HTML代码:

<!DOCTYPE html>
<html>
<head><title>MBTI Test</title><link rel="stylesheet" type="text/css" href="style.css">
</head>
<body><div class="container"><h1>MBTI Test</h1><p>请回答以下问题:</p><form><div class="question"><p>1. 你更喜欢:</p><label><input type="radio" name="q1" value="E">A. 外向、喜欢社交</label><label><input type="radio" name="q1" value="I">B. 内向、喜欢独处</label></div><div class="question"><p>2. 你更关注:</p><label><input type="radio" name="q2" value="S">A. 具体的细节和事实</label><label><input type="radio" name="q2" value="N">B. 抽象的概念和理论</label></div><div class="question"><p>3. 你更喜欢:</p><label><input type="radio" name="q3" value="T">A. 逻辑和分析</label><label><input type="radio" name="q3" value="F">B. 情感和价值</label></div><div class="question"><p>4. 你更倾向于:</p><label><input type="radio" name="q4" value="J">A. 计划和组织</label><label><input type="radio" name="q4" value="P">B. 灵活和开放</label></div><button type="submit">提交</button></form></div><script src="script.js"></script>
</body>
</html>

CSS代码:

.container {max-width: 600px;margin: 0 auto;padding: 20px;text-align: center;
}.question {margin-bottom: 20px;text-align: left;
}

JS代码:

// 定义问题和答案的数组
var questions = [{question: "你更喜欢:",answers: [{ type: "E", content: "A. 外向、喜欢社交" },{ type: "I", content: "B. 内向、喜欢独处" }]},{question: "你更关注:",answers: [{ type: "S", content: "A. 具体的细节和事实" },{ type: "N", content: "B. 抽象的概念和理论" }]},{question: "你更喜欢:",answers: [{ type: "T", content: "A. 逻辑和分析" },{ type: "F", content: "B. 情感和价值" }]},{question: "你更倾向于:",answers: [{ type: "J", content: "A. 计划和组织" },{ type: "P", content: "B. 灵活和开放" }]}
];// 获取DOM元素
var form = document.querySelector("form");
var result = document.createElement("p");// 绑定提交事件
form.addEventListener("submit", function(event) {event.preventDefault();// 计算分数var scores = { E: 0, I: 0, S: 0, N: 0, T: 0, F: 0, J: 0, P: 0 };var answers = form.querySelectorAll("input[type='radio']:checked");for (var i = 0; i < answers.length; i++) {scores[answers[i].value]++;}// 根据分数计算MBTI类型var mbtiType = "";if (scores.E > scores.I) {mbtiType += "E";} else {mbtiType += "I";}if (scores.S > scores.N) {mbtiType += "S";} else {mbtiType += "N";}if (scores.T > scores.F) {mbtiType += "T";} else {mbtiType += "F";}if (scores.J > scores.P) {mbtiType += "J";} else {mbtiType += "P";}// 显示结果result.textContent = "您的MBTI类型为:" + mbtiType;form.appendChild(result);
});

解析注释:

这个网页包含了四个问题,每个问题有两个答案选项。用户选择答案后,点击提交按钮,会计算用户的分数,并根据分数计算出MBTI类型,最后显示在页面上。

HTML部分包含了一个标题、四个问题和一个提交按钮。每个问题包含两个答案选项,使用单选按钮实现。CSS部分定义了一些基本样式,使页面看起来更美观。

JS部分定义了一个问题和答案的数组,包含四个问题和每个问题的两个答案选项。当用户点击提交按钮时,会计算用户的分数,并根据分数计算出MBTI类型。最后,将MBTI类型显示在页面上。

计算分数的方法是通过循环遍历所有选中的单选按钮,并将选中答案的类型加到对应的分数上。计算MBTI类型的方法是通过比较每个维度的分数大小,将分数较高的选项作为MBTI类型的值。最后,将MBTI类型显示在页面上。

这篇关于简单的MBTI测试的Web网页的HTML、CSS和JS代码,以及解析注释:的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/214355

相关文章

线上Java OOM问题定位与解决方案超详细解析

《线上JavaOOM问题定位与解决方案超详细解析》OOM是JVM抛出的错误,表示内存分配失败,:本文主要介绍线上JavaOOM问题定位与解决方案的相关资料,文中通过代码介绍的非常详细,需要的朋... 目录一、OOM问题核心认知1.1 OOM定义与技术定位1.2 OOM常见类型及技术特征二、OOM问题定位工具

C#实现千万数据秒级导入的代码

《C#实现千万数据秒级导入的代码》在实际开发中excel导入很常见,现代社会中很容易遇到大数据处理业务,所以本文我就给大家分享一下千万数据秒级导入怎么实现,文中有详细的代码示例供大家参考,需要的朋友可... 目录前言一、数据存储二、处理逻辑优化前代码处理逻辑优化后的代码总结前言在实际开发中excel导入很

SpringBoot+RustFS 实现文件切片极速上传的实例代码

《SpringBoot+RustFS实现文件切片极速上传的实例代码》本文介绍利用SpringBoot和RustFS构建高性能文件切片上传系统,实现大文件秒传、断点续传和分片上传等功能,具有一定的参考... 目录一、为什么选择 RustFS + SpringBoot?二、环境准备与部署2.1 安装 RustF

Python实现Excel批量样式修改器(附完整代码)

《Python实现Excel批量样式修改器(附完整代码)》这篇文章主要为大家详细介绍了如何使用Python实现一个Excel批量样式修改器,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一... 目录前言功能特性核心功能界面特性系统要求安装说明使用指南基本操作流程高级功能技术实现核心技术栈关键函

Vue和React受控组件的区别小结

《Vue和React受控组件的区别小结》本文主要介绍了Vue和React受控组件的区别小结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学... 目录背景React 的实现vue3 的实现写法一:直接修改事件参数写法二:通过ref引用 DOMVu

Java实现将HTML文件与字符串转换为图片

《Java实现将HTML文件与字符串转换为图片》在Java开发中,我们经常会遇到将HTML内容转换为图片的需求,本文小编就来和大家详细讲讲如何使用FreeSpire.DocforJava库来实现这一功... 目录前言核心实现:html 转图片完整代码场景 1:转换本地 HTML 文件为图片场景 2:转换 H

C#使用Spire.Doc for .NET实现HTML转Word的高效方案

《C#使用Spire.Docfor.NET实现HTML转Word的高效方案》在Web开发中,HTML内容的生成与处理是高频需求,然而,当用户需要将HTML页面或动态生成的HTML字符串转换为Wor... 目录引言一、html转Word的典型场景与挑战二、用 Spire.Doc 实现 HTML 转 Word1

Vue3绑定props默认值问题

《Vue3绑定props默认值问题》使用Vue3的defineProps配合TypeScript的interface定义props类型,并通过withDefaults设置默认值,使组件能安全访问传入的... 目录前言步骤步骤1:使用 defineProps 定义 Props步骤2:设置默认值总结前言使用T

深度解析Python中递归下降解析器的原理与实现

《深度解析Python中递归下降解析器的原理与实现》在编译器设计、配置文件处理和数据转换领域,递归下降解析器是最常用且最直观的解析技术,本文将详细介绍递归下降解析器的原理与实现,感兴趣的小伙伴可以跟随... 目录引言:解析器的核心价值一、递归下降解析器基础1.1 核心概念解析1.2 基本架构二、简单算术表达

Three.js构建一个 3D 商品展示空间完整实战项目

《Three.js构建一个3D商品展示空间完整实战项目》Three.js是一个强大的JavaScript库,专用于在Web浏览器中创建3D图形,:本文主要介绍Three.js构建一个3D商品展... 目录引言项目核心技术1. 项目架构与资源组织2. 多模型切换、交互热点绑定3. 移动端适配与帧率优化4. 可