为了账号安全,请及时绑定邮箱和手机立即绑定

如何在单击按钮时删除特定数量的 DOM 元素?

如何在单击按钮时删除特定数量的 DOM 元素?

拉丁的传说 2023-04-01 16:10:44
我想弄清楚如何在单击按钮时删除按钮上方最近的四个 div 元素(连同包含按钮的 div)。我一直在尝试使用.closest(),但运气不佳。我将始终删除按钮本身以及 DOM 顺序中按钮上方的四个元素。下面有多组带有 div 的行,所以我不能单独按类选择这些元素。示例 HTML://Row 1<div class="col-2 selectedRow">014</div><div class="col-4 selectedRow">Test</div><div class="col-2 selectedRow">Special Charge</div><div class="col-2 selectedRow">012</div><div class="col-2 selectedRow"><input type="button" class="removeCode" value="Remove"></div>//Row 2<div class="col-2 selectedRow">012</div><div class="col-4 selectedRow">Test 2</div><div class="col-2 selectedRow">Other Charge</div><div class="col-2 selectedRow">011</div><div class="col-2 selectedRow"><input type="button" class="removeCode" value="Remove"></div>Java脚本:$("form").on('click', '.removeCode', function (event) {    //Remove the current div container, and the 4 divs above that element in the DOM order.});
查看完整描述

1 回答

?
largeQ

TA贡献2039条经验 获得超7个赞

您需要对 HTML 文件进行更改,例如:

  1. input将您的元素替换为button并应用与 wrapper 相同的样式div

  2. 将单个行包围在容器中

  3. 单击时删除单击按钮的容器

例如:

$("form .removeCode").click(function(event) {

  $(this).parent(".container").remove();

});

<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>

<form>

  <div class="container">

    <div class="col-2 selectedRow">014</div>

    <div class="col-4 selectedRow">Test</div>

    <div class="col-2 selectedRow">Special Charge</div>

    <div class="col-2 selectedRow">012</div>

    <button type="button" class="col-2 selectedRow removeCode">Remove</button>

  </div>

  </div>


  <div class="container">

    <div class="col-2 selectedRow">012</div>

    <div class="col-4 selectedRow">Test 2</div>

    <div class="col-2 selectedRow">Other Charge</div>

    <div class="col-2 selectedRow">011</div>

    <button type="button" class="col-2 selectedRow removeCode">Remove</button>

  </div>

</form>


查看完整回答
反对 回复 2023-04-01
  • 1 回答
  • 0 关注
  • 108 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信