
本文将介绍如何使用 JavaScript 将 HTML 中的 div 元素模拟为单选按钮,并在用户选择某个 div 时,获取该 div 内部特定元素的值并存储到变量中。通过监听 div 的点击事件,动态改变选中 div 的背景颜色,并通过 this 关键字和 find() 方法,精准定位并提取目标数据,实现类似单选按钮的功能。
实现步骤
- HTML 结构
首先,需要一个包含多个 div 元素的 HTML 结构。每个 div 元素都具有相同的类名(例如 package),并且包含需要提取数据的子元素。
<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/1077" title="海绵音乐"><img
src="https://img.php.cn/upload/ai_manual/000/000/000/175680046830886.png" alt="海绵音乐" onerror="this.onerror='';this.src='/static/lhimages/moren/morentu.png'" ></a>
<div class="aritcle_card_info flexColumn">
<a href="/ai/1077" title="海绵音乐">海绵音乐</a>
<p>字节跳动推出的AI音乐生成工具</p>
</div>
<a href="/ai/1077" 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 代码
接下来,使用 JavaScript 代码来实现 div 的单选按钮行为,并在点击时获取数据。
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 的背景颜色
const elem = $(this);
elem.css("background-color", "#FCF6CC");
// 获取当前点击的 package 内部的数据
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 元素的背景颜色重置为白色,模拟单选按钮的互斥效果。
- const elem = $(this);: 使用 $(this) 获取当前点击的 div 元素,并将其存储在变量 elem 中。
- elem.css("background-color", "#FCF6CC");: 设置当前点击的 div 元素的背景颜色,表示选中状态。
- elem.find('.packageId').attr('value'): 使用 elem.find() 方法在当前点击的 div 元素内部查找类名为 packageId 的元素,并使用 .attr('value') 获取其 value 属性的值。
- elem.find('.packageTitle').text(): 使用 elem.find() 方法在当前点击的 div 元素内部查找类名为 packageTitle 的元素,并使用 .text() 获取其文本内容。
- elem.find('.packagePrice').text(): 使用 elem.find() 方法在当前点击的 div 元素内部查找类名为 packagePrice 的元素,并使用 .text() 获取其文本内容。
- console.log(...): 将获取到的数据打印到控制台。
注意事项
- 确保引入 jQuery 库,因为代码中使用了 jQuery 的 $ 符号和相关方法。
- $(this) 指的是当前点击的 div 元素,通过它可以使用 jQuery 的 find() 方法在当前 div 内部查找元素。
- 使用 elem.find() 方法可以确保只在当前点击的 div 内部查找目标元素,避免获取到其他 div 中的数据。
总结
通过以上步骤,就可以使用 JavaScript 将 div 元素模拟为单选按钮,并在用户选择某个 div 时,获取该 div 内部特定元素的值并存储到变量中。 这种方法可以灵活地应用于各种需要自定义选择控件的场景。









