新闻中心

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

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

使用html和javascript实现多选题切换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来实现点击选项按钮后切换div显示的效果。

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 文件上传教程:解决图片无法保存到模型的常见问题 

搜索