新闻中心
使用HTML和J*aScript实现多选题切换Div显示效果

本文旨在指导开发者如何使用HTML和J*aScript实现一个简单的多选题切换Div显示效果。通过监听按钮点击事件,控制不同Div的显示与隐藏,从而实现题目切换的交互效果。文章将提供详细的代码示例和解释,并针对常见问题提供解决方案。
HTML结构
首先,我们需要创建HTML结构,使用多个div元素来表示不同的题目。每个div包含题目内容和多个选项按钮。
<div class="box box1">
<h1>Awesome Quiz</h1>
<p>Trivia Time ??!!!</p>
<button id="start">Start</button>
</div>
<div class="quest box2">
<h2>Awesome Quiz</h2>
<p>Who was the first President of the United States?</p>
<p>George Washington</p>
<button class="option option1">SELECT ANSWER</button>
<p>Thomas Jefferson</p>
<button class="option option2">SELECT ANSWER</button>
<p>Thomas Edinson</p>
<button class="option option3">SELECT ANSWER</button>
<p>I don't Know</p>
<button class="option option4">SELECT ANSWER</button>
<div class="page">
<p>Question 1 of 5</p>
</div>
</div>
<div class="quest box3">
<h2>Awesome Quiz</h2>
<p>What is Queen Elizabeth II's surname?</p>
<p>Jason</p>
<button class="option option1">SELECT ANSWER</button>
<p>Windsor</p>
<button class="option option2">SELECT ANSWER</button>
<p>Drakeford</p>
<button class="option option3">SELECT ANSWER</button>
<p>William</p>
<button class="option option4">SELECT ANSWER</button>
<div class="page">
<p>Question 2 of 5</p>
<div class="aritcle_card">
<a class="aritcle_card_img" href="/ai/1540">
<img src="https://img.php.cn/upload/ai_manual/000/969/633/68b7a213277e9355.png" alt="AI Surge Cloud">
</a>
<div class="aritcle_card_info">
<a href="/ai/1540">AI Surge Cloud</a>
<p>低代码数据分析平台,帮助企业快速交付深度数据</p>
<div class="">
<img src="/static/images/card_xiazai.png" alt="AI Surge Cloud">
<span>87</span>
</div>
</div>
<a href="/ai/1540" class="aritcle_card_btn">
<span>查看详情</span>
<img src="/static/images/cardxiayige-3.png" alt="AI Surge Cloud">
</a>
</div>
</div>
</div>
<div class="quest box4">
<h2>Awesome Quiz</h2>
<p>What is the largest country in the world?</p>
<p>Russia</p>
<button class="option option1">SELECT ANSWER</button>
<p>Canada</p>
<button class="option option2">SELECT ANSWER</button>
<p>India</p>
<button class="option option3">SELECT ANSWER</button>
<p>South Africa</p>
<button class="option option4">SELECT ANSWER</button>
<div class="page">
<p>Question 3 of 5</p>
</div>
</div>每个题目div都具有唯一的类名(如box2、box3等),选项按钮也具有相同的类名option。
J*aScript实现
接下来,使用J*aScript来实现点击选项按钮后切换di
v显示的效果。
let start = document.querySelector('#start');
let intro = document.querySelector('.box1');
let quest = document.querySelector('.quest');
let box2 = document.querySelector('.box2');
let box3 = document.querySelector('.box3');
let box4 = document.querySelector('.box4');
let box5 = document.querySelector('.box5');
let box6 = document.querySelector('.box6');
let select1 = document.querySelector('.box2 .option'); // using querySelector here too
let select2 = document.querySelector('.box3 .option');
let select3 = document.querySelector('.box4 .option');
let select4 = document.querySelector('.box5 .option');
let select5 = document.querySelector('.box6 .option');
start.addEventListener('click', function(){
intro.style.display = 'none';
box2.style.display = 'block';
})
select1.addEventListener('click', function(){
box2.style.display = 'none';
box3.style.display = 'block';
})
select2.addEventListener('click', function(){
box3.style.display = 'none';
box4.style.display = 'block';
})
select3.addEventListener('click', function(){
box4.style.display = 'none';
box5.style.display = 'block';
})
// Commenting this out because there is no .box5 element in the HTML
// select4.addEventListener('click', function(){
// box5.style.display = 'none';
// box6.style.display = 'block';
// })这段代码首先获取所有需要操作的HTML元素,包括题目div和选项按钮。然后,为每个选项按钮添加点击事件监听器。当点击按钮时,隐藏当前div,显示下一个div。
注意: 上述代码中使用了 document.querySelector 方法,它只会返回匹配选择器的第一个元素。这意味着每个题目只有第一个选项按钮会触发切换效果。
改进方案:使用 querySelectorAll
为了解决上述问题,我们需要使用 document.querySelectorAll 方法,它会返回匹配选择器的所有元素。然后,我们可以遍历所有选项按钮,为每个按钮添加点击事件监听器。
const optionButtons = document.querySelectorAll('.option');
optionButtons.forEach(button => {
button.addEventListener('click', function() {
// 获取当前题目div
const currentQuestion = this.closest('.quest');
// 隐藏当前题目div
currentQuestion.style.display = 'none';
// 获取下一个题目div
const nextQuestion = currentQuestion.nextElementSibling;
// 显示下一个题目div
if (nextQuestion && nextQuestion.classList.contains('quest')) {
nextQuestion.style.display = 'block';
} else {
// 如果没有下一个题目,可以显示完成页面或者其他操作
alert('Quiz completed!');
}
});
});
let start = document.querySelector('#start');
let intro = document.querySelector('.box1');
start.addEventListener('click', function(){
intro.style.display = 'none';
document.querySelector('.box2').style.display = 'block';
})这段代码首先使用 document.querySelectorAll('.option') 获取所有选项按钮。然后,使用 forEach 方法遍历每个按钮,并添加点击事件监听器。在事件处理函数中,使用 this.closest('.quest') 获取当前按钮所在的题目div,并隐藏它。接着,使用 nextElementSibling 获取下一个兄弟元素,并判断它是否是题目div。如果是,则显示下一个题目div。
总结
本文介绍了如何使用HTML和J*aScript实现一个简单的多选题切换Div显示效果。通过监听按钮点击事件,控制不同Div的显示与隐藏,从而实现题目切换的交互效果。同时,针对 querySelector 只能获取第一个匹配元素的问题,提出了使用 querySelectorAll 的解决方案。希望本文能帮助开发者更好地理解和应用J*aScript来实现动态的Web页面交互效果。
以上就是使用HTML和J*aScript实现多选题切换Div显示效果的详细内容,更多请关注其它相关文章!
# 多个
# 马鞍山seo推广报价
# 潢川网络推广营销中心
# 怎么制作小说网站推广
# 博罗网站建设哪家实惠
# 合伙建设网站
# 北京饭店网站建设银行
# 团购账号如何做营销推广
# 江苏汽车营销推广
# seo实操
# 贵阳网站建设网络优化
# 连接到
# 来实现
# 这段
# 遍历
# javascript
# 选择器
# 多选题
# 第一个
# 置顶
# 显示效果
# html元素
# 点击事件
# 常见问题
# win
# ai
# ssl
# html
# java
相关栏目:
【
科技资讯46185 】
【
网络学院92790 】
相关推荐:
AI泡沫首次被“刺破”:GPU十年都无法存活!
漫蛙漫画官方主页入口 漫蛙MANWA网页直达访问链接
163邮箱网页版入口导航平台 163邮箱网页版登录入口官网导航
大象笔记网页版入口 印象笔记网页版登录入口
优化HTML表单样式:解决输入框焦点跳动与元素间距问题
iwriter统一登录平台 iwrite账号密码登录页面
Mac怎么锁定备忘录_Mac备忘录加密设置教程
jQuery Mask 插件中实现电话号码固定前导零的教程
C++如何使用AddressSanitizer(ASan)_C++调试工具中检测内存访问错误的利器
Win11怎么关闭触摸屏_Windows 11禁用HID符合标准触摸屏
京东单号查询入口_京东快递订单追踪入口
Win10桌面图标出现小盾牌怎么办 Win10去除UAC图标教程【解决】
小米Civi 4录制视频过暗_小米Civi 4亮度优化
Python多线程中正确使用sigwait处理SIGALRM信号
不同用户不同价格! 索尼开启账户个性化定价测试
Go RPC HTTP服务正确实现与常见陷阱解析
在J*a中如何隐藏复杂性_使用门面模式组织对象交互
快手赚钱渠道_快手收益来源
React Router 嵌套组件中 URL 重定向问题的解决方案
如何使用CaptainHook和Composer管理Git钩子_在提交前自动运行代码检查的Composer配置
俄罗斯浏览器官网直达链接 俄罗斯浏览器最新在线入口导航
Python自定义类排序:解决lambda键值访问TypeError的实践指南
C++如何生成随机数_C++ random库使用方法与范围设置
荣耀Play7TPro怎样在信息App置顶客服对话_iPhone荣耀Play7TPro信息App置顶客服对话【优先查看】
网易大神账号申诉需要多久_网易大神账号申诉流程说明
Lar*el 8 多关键词数据库搜索优化实践
解决Django多数据库/多Schema环境下外键迁移问题
Node.js CSV 数据处理:基于字段空值条件过滤整条记录的策略
C++如何实现线程池_C++11手动实现一个简单的固定大小线程池
PPT平滑切换怎么做 PPT炫酷“平滑”切换动画制作教程【必学】
J*a里如何使用N*igableMap进行导航操作_可导航Map操作技巧解析
Tabulator表格日期时间排序问题及自定义解决方案
MongoDB聚合管道:正确匹配对象数组中_id的方法
j*a toString()的覆盖
Golang如何处理RPC请求负载均衡_Golang RPC请求负载均衡策略与实践
AO3官方镜像站点汇总 AO3同人作品网页版直达链接
谷歌浏览器一键优化方案_谷歌浏览器直达主页极速不卡版
c++如何使用std::memory_order控制原子操作顺序_c++ C++11内存模型详解
Win11网速慢怎么解决 Win11网络设置优化解除限速
J*aScript map 方法中处理循环元素为空数组的策略
腾讯视频怎么举报不良内容_腾讯视频内容举报流程与违规信息处理方法
俄罗斯搜索引擎Yandex指南 附2025年免登录官网入口
PHP中获取MongoDB服务器运行时间(Uptime)的专业指南
c++ dfs和bfs代码 c++深度广度优先搜索算法
现代化 SciPy 一维插值:interp1d 的替代方案与最佳实践
J*aScript中高效清空DOM列表元素:解决for循环中断与任务管理问题
Descript怎样用AI剪辑自动去噪_Descript用AI剪辑自动去噪【自动降噪】
《铁拳8》黑皮辣妹新实机:元气满满的18岁少女!
微博网页版主页入口 微博官方网站免登录访问
Django AJAX 文件上传教程:解决图片无法保存到模型的常见问题


2025-10-18
浏览次数:次
返回列表