
本文旨在解决在包含多个表单的页面中,当不同表单中存在同名类时,如何使用 JavaScript准确访问特定表单内的类元素的问题。通过修改选择器和使用console.log进行调试,可以轻松定位和操作目标元素。本文提供了详细的代码示例和注意事项,帮助开发者避免常见错误,提升开发效率。
当网页中存在多个表单,并且这些表单中使用了相同的类名时,直接使用 document.getElementsByClassName() 方法可能会导致选取到错误的元素。为了准确地访问特定表单内的元素,我们需要结合表单的 id 属性和 document.getElementById() 方法。
正确的选择器使用
document.getElementById() 方法用于根据元素的 id 属性获取元素。与使用 CSS 选择器(例如 #productId_1)不同,该方法只需要传入 id 属性的值(例如 productId_1)。
立即学习“Java免费学习笔记(深入)”;
示例代码
本系统经过多次升级改造,系统内核经过多次优化组合,已经具备相对比较方便快捷的个性化定制的特性,用户部署完毕以后,按照自己的运营要求,可实现快速定制会费管理,支持在线缴费和退费功能财富中心,管理会员的诚信度数据单客户多用户登录管理全部信息支持审批和排名不同的会员级别有不同的信息发布权限企业站单独生成,企业自主决定更新企业站信息留言、询价、报价统一管理,分系统查看分类信息参数化管理,支持多样分类信息,
0
以下示例演示了如何通过表单的 id 属性和 getElementsByClassName() 方法来访问表单内的特定类元素。
document.addEventListener("DOMContentLoaded", () => {
const product1 = document.querySelector("#productId_1")
const product2 = document.querySelector("#productId_2")
const product3 = document.querySelector("#productId_3")
product1.addEventListener("submit", e => {
e.preventDefault();
var formId = "productId_1";
productList(formId);
});
product2.addEventListener("submit", e => {
e.preventDefault();
var formId = "productId_2";
productList(formId);
});
product3.addEventListener("submit", e => {
e.preventDefault();
var formId = "productId_3";
productList(formId);
});
});
function productList(formId) {
var a = document.getElementById(formId).getElementsByClassName("productId")[0];
//testing
console.log(formId, a.value);
}<div class="productContainer">
<h1 class="productTitle">Products:</h1>
<div class="container">
<form action="" class="product" id="productId_1">
<h1>balls</h1>
<p>a ball bering</p>
<input type="hidden" class="productId" value="item_1">
<button class="submit">Purchase</button>
</form>
</div>
<div class="container">
<form action="" class="product" id="productId_2">
<h1>balls</h1>
<p>a ball bering</p>
<input type="hidden" class="productId" value="item_2">
<button class="submit">Purchase</button>
</form>
</div>
<div class="container" class="product" id="productId_3">
<form action="" class="product">
<h1>balls</h1>
<p>a ball bering</p>
<input type="hidden" class="productId" value="item_3">
<button class="submit">Purchase</button>
</form>
</div>
</div>代码解释
注意事项
总结
通过结合 document.getElementById() 和 getElementsByClassName() 方法,可以准确地访问包含多个表单的页面中特定表单内的类元素。正确使用选择器和调试工具可以帮助开发者避免常见错误,提高开发效率。
以上就是JavaScript:在具有相同类名的多个表单中访问特定类的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号