0

0

使用 JavaScript 将 Div 模拟为单选按钮并提取数据

碧海醫心

碧海醫心

发布时间:2025-08-31 11:16:12

|

260人浏览过

|

来源于php中文网

原创

使用 javascript 将 div 模拟为单选按钮并提取数据

本教程将介绍如何使用 JavaScript 将 HTML 中的 div 元素模拟为单选按钮,并在用户选择某个 div 时,提取该 div 内部特定元素的值,并将这些值存储到变量中。我们将重点讲解如何避免因类名重复而导致的数据提取错误,并提供清晰的代码示例。

实现 Div 的单选按钮效果

首先,我们需要 HTML 结构。假设我们有多个 div 元素,它们具有相同的类名(例如,package),并且每个 div 内部包含一些我们需要提取数据的元素:

<div class="col-lg-4 text-center">
    <div class="package">
        <input type="hidden" class="packageId" value="5" />
        <p class="small">Deep</p>
        <h4 class="packageTitle">Deep Cleaning</h4>
        <p>All-inclusive cleaning service</p>
        <p class="small">Price Per Cleaner</p>
        <p class="price packagePrice">41.90 <span class="small">/h</span></p>
    </div>
</div>
<div class="col-lg-4 text-center">
    <div class="package">
        <input type="hidden" class="packageId" value="4" />
        <p class="small">Last Minute</p>
        <h4 class="packageTitle">Last-Minute Cleaning</h4>
        <p>Last minute & after party cleaning</p><p><span>立即学习</span>“<a href="https://pan.quark.cn/s/c1c2c2ed740f" style="text-decoration: underline !important; color: blue; font-weight: bolder;" rel="nofollow" target="_blank">Java免费学习笔记(深入)</a></a>”;</p><div class="aritcle_card flexRow">
                                                        <div class="artcardd flexRow">
                                                                <a class="aritcle_card_img" href="/ai/1328" title="小艺"><img
                                                                                src="https://img.php.cn/upload/ai_manual/000/000/000/175680183422075.png" alt="小艺"  onerror="this.onerror='';this.src='/static/lhimages/moren/morentu.png'" ></a>
                                                                <div class="aritcle_card_info flexColumn">
                                                                        <a href="/ai/1328" title="小艺">小艺</a>
                                                                        <p>华为公司推出的AI智能助手</p>
                                                                </div>
                                                                <a href="/ai/1328" title="小艺" class="aritcle_card_btn flexRow flexcenter"><b></b><span>下载</span> </a>
                                                        </div>
                                                </div>
        <p class="small">Price Per Cleaner</p>
        <p class="price packagePrice">43.90 <span class="small">/h</span></p>
    </div>
</div>
<div class="col-lg-4 text-center">
    <div class="package">
        <input type="hidden" class="packageId" value="3" />
        <p class="small">Moving</p>
        <h4 class="packageTitle">Move-In-Out Cleaning</h4>
        <p>For move-ins, and move-outs</p>
        <p class="small">Price Per Cleaner</p>
        <p class="price packagePrice">41.90 <span class="small">/h</span></p>
    </div>
</div>

接下来,我们将使用 JavaScript 来实现以下功能:

  1. 点击某个 div 时,改变其背景颜色,以突出显示选中状态。
  2. 提取被点击 div 内部特定元素的值,并将其存储到变量中。

JavaScript 代码实现

var packageId = "";
var packageTitle = "";
var packagePrice = "";
var packages = document.getElementsByClassName('package');

Array.prototype.forEach.call(packages, function (element) {
    element.addEventListener('click', function () {
        // 移除所有 package 的背景色
        $('.package').css("background-color", "#FFFFFF");
        // 设置当前点击的 package 的背景色
        $(this).css("background-color", "#FCF6CC");

        // 使用 $(this) 查找当前点击的 package 内部的元素
        const elem = $(this);
        packageId = elem.find('.packageId').attr('value');
        packageTitle = elem.find('.packageTitle').text();
        packagePrice = elem.find('.packagePrice').text();

        console.log("Package ID:", packageId);
        console.log("Package Title:", packageTitle);
        console.log("Package Price:", packagePrice);
    });
});

代码解释:

  • document.getElementsByClassName('package'): 获取所有类名为 package 的元素。
  • Array.prototype.forEach.call(packages, function (element) { ... }): 遍历所有 package 元素,并为每个元素添加点击事件监听器。
  • $('.package').css("background-color", "#FFFFFF");: 移除所有 package 元素的背景颜色,确保只有一个 div 处于选中状态。
  • $(this).css("background-color", "#FCF6CC");: $(this) 指的是当前点击的 div 元素,设置其背景颜色。
  • const elem = $(this);: 将当前点击的元素缓存到 elem 变量中,方便后续查找其内部元素。
  • elem.find('.packageId').attr('value'): 在当前点击的 div 元素内部查找类名为 packageId 的元素,并获取其 value 属性值。 关键点:使用 elem.find() 而不是 $('.packageId'),可以确保只在当前点击的 div 内部查找,避免因类名重复而获取到错误的值。
  • elem.find('.packageTitle').text(): 在当前点击的 div 元素内部查找类名为 packageTitle 的元素,并获取其文本内容。
  • elem.find('.packagePrice').text(): 在当前点击的 div 元素内部查找类名为 packagePrice 的元素,并获取其文本内容。
  • console.log(...): 将提取到的值打印到控制台,方便调试。

注意事项

  • 确保引入了 jQuery 库,因为代码中使用了 $ 符号。
  • find() 方法是 jQuery 的方法,用于在指定元素内部查找匹配选择器的元素。
  • 如果 HTML 结构发生变化,需要相应地修改 JavaScript 代码中的选择器。

总结

通过本教程,你学习了如何使用 JavaScript 将 div 元素模拟为单选按钮,并在用户选择某个 div 时,提取该 div 内部特定元素的值。 关键在于使用 $(this).find() 方法来确保只在当前点击的 div 内部查找元素,避免因类名重复而导致的数据提取错误。 这种方法可以应用于各种需要自定义单选按钮样式并提取相关数据的场景。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
jquery插件有哪些
jquery插件有哪些

jquery插件有jQuery UI、jQuery Validate、jQuery DataTables、jQuery Slick、jQuery LazyLoad、jQuery Countdown、jQuery Lightbox、jQuery FullCalendar、jQuery Chosen和jQuery EasyUI等。本专题为大家提供jquery插件相关的文章、下载、课程内容,供大家免费下载体验。

156

2023.09.12

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

331

2023.10.13

jquery删除元素的方法
jquery删除元素的方法

jquery可以通过.remove() 方法、 .detach() 方法、.empty() 方法、.unwrap() 方法、.replaceWith() 方法、.html('') 方法和.hide() 方法来删除元素。更多关于jquery相关的问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

405

2023.11.10

jQuery hover()方法的使用
jQuery hover()方法的使用

hover()是jQuery中一个常用的方法,它用于绑定两个事件处理函数,这两个函数将在鼠标指针进入和离开匹配的元素时执行。想了解更多hover()的相关内容,可以阅读本专题下面的文章。

515

2023.12.04

jquery实现分页方法
jquery实现分页方法

在jQuery中实现分页可以使用插件或者自定义实现。想了解更多jquery分页的相关内容,可以阅读本专题下面的文章。

311

2023.12.06

jquery中隐藏元素是什么
jquery中隐藏元素是什么

jquery中隐藏元素是非常重要的一个概念,在使用jquery隐藏元素之前,需要先了解css样式中关于元素隐藏的属性,比如display、visibility、opacity等属性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

128

2024.02.23

jquery中什么是高亮显示
jquery中什么是高亮显示

jquery中高亮显示是指对页面搜索关键词时进行高亮显示,其实现办法:1、先获取要高亮显示的行,获取搜索的内容,再遍历整行内容,最后添加高亮颜色;2、使用“jquery highlight”高亮插件。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

180

2024.02.23

jQuery 正则表达式相关教程
jQuery 正则表达式相关教程

本专题整合了jQuery正则表达式相关教程大全,阅读专题下面的文章了解更多详细内容。

50

2026.01.13

JavaScript浏览器渲染机制与前端性能优化实践
JavaScript浏览器渲染机制与前端性能优化实践

本专题围绕 JavaScript 在浏览器中的执行与渲染机制展开,系统讲解 DOM 构建、CSSOM 解析、重排与重绘原理,以及关键渲染路径优化方法。内容涵盖事件循环机制、异步任务调度、资源加载优化、代码拆分与懒加载等性能优化策略。通过真实前端项目案例,帮助开发者理解浏览器底层工作原理,并掌握提升网页加载速度与交互体验的实用技巧。

1

2026.03.06

热门下载

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

精品课程

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

共14课时 | 0.9万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.5万人学习

CSS教程
CSS教程

共754课时 | 40.3万人学习

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

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