jquery 如何最好地清除div中的innerHTML元素而不删除元素

2nc8po8w  于 2023-06-22  发布在  jQuery
关注(0)|答案(2)|浏览(241)

我试图清除父元素的每个子元素中的数据,而不删除(或隐藏)实际的子元素。
要重现问题:

  • 输入Test1Test2的数据
  • 单击复选框“使用实际数据”,然后输入Test 3Test 4的数据。
  • 按下“清除测试1和2的元素数据”按钮。

这是为了删除innerHTML数据,而不是元素本身。
我希望元素保持可见和可用,只是没有任何数据。我只希望数据被清除。
我该怎么做?

$(function() {
  $("#actual").click(function() {
    if ($("#actual").is(":checked")) {
      $("#utility-info").hide();
      $("#actual-utils").show();
    } else {
      $("#utility-info").show();
      $("#actual-utils").hide();
    }
  });

  $("#clear-values").click(function() {
    $("#utility-info").html('');
  });
});
#actual-utils {
  display: none;
}

span {
  padding: 10px;
}
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>

<input type="checkbox" id="actual" name="actual-util-info"> Use actual data
<div>&nbsp;</div>
<div id="energy-info">
  <div id="utility-info">
    <div>Test 1 <input id="test1" type="number" name="test1"></div>
    <div>Test 2 <input id="test2" type="number" name="test2"></div>
  </div>
  <div id="actual-utils">
    <div>Test 3 <input id="actual1" type="number" name="actual1"></div>
    <div>Test 4 <input id="actual2" type="number" name="actual2"></div>
  </div>
  <div>&nbsp;</div>
  <button id="clear-values">Clear Element Data for Tests 1 & 2</button>
</div>
nlejzf6q

nlejzf6q1#

这个问题是因为您正在清除#utility-info的 * 整个 * 内容,其中包含input元素及其值。
要解决此问题,请将选择器更改为直接针对input元素,然后使用val('')清除值。
还请注意,您可以通过缓存在调用DOM时创建的jQuery对象,以及通过使用toggle()方法来隐藏/显示基于checkbox的boolean checked属性的div元素,来改进逻辑并使其更加简洁。
下面是一个工作示例:

jQuery($ => {
  const $utilityInfo = $('#utility-info');
  const $actualUtils = $('#actual-utils');

  $('#actual').on('click', e => {
    const useActual = e.target.checked;
    $utilityInfo.toggle(!useActual);
    $actualUtils.toggle(useActual);
  });

  $('#clear-values').click(function() {
    $utilityInfo.find('input').val('');
  });
});
#actual-utils {
  display: none;
}

span {
  padding: 10px;
}
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<input type="checkbox" id="actual" name="actual-util-info"> Use actual data
<div>&nbsp;</div>
<div id="energy-info">
  <div id="utility-info">
    <div>Test 1 <input id="test1" type="number" name="test1"></div>
    <div>Test 2 <input id="test2" type="number" name="test2"></div>
  </div>
  <div id="actual-utils">
    <div>Test 3 <input id="actual1" type="number" name="actual1"></div>
    <div>Test 4 <input id="actual2" type="number" name="actual2"></div>
  </div>
  <div>&nbsp;</div>
  <button id="clear-values">Clear Element Data for Tests 1 & 2</button>
</div>
km0tfn4u

km0tfn4u2#

best™”可能是实际使用声明式HTML,它可以在没有JS的情况下为您完成所有这些。<form>及其所有内部<input>元素可以通过<button type="reset">(或等效的<input type="reset">)重置为原始值。
除了对AT和机器完全清楚你的标记是什么,以及在JS被禁用的地方工作之外,它还允许你设置一个初始值并将其重置回来。

/* Toggle the checkbox to show one form at a time */
#actual:checked ~ * #utility-info,
#actual:not(:checked) ~ * #actual-utils {
  display: none;
}
span {
  padding: 10px;
}
<input type="checkbox" id="actual" name="actual-util-info"> Use actual data
<div>&nbsp;</div>
<div id="energy-info">
  <!-- Wrap in <form> elements -->
  <form id="utility-info">
    <div>Test 1 <input id="test1" type="number" name="test1"></div>
    <div>Test 2 <input id="test2" type="number" name="test2"></div>
  </form>
  <!-- Wrap in <form> elements -->
  <form id="actual-utils">
    <div>Test 3 <input id="actual1" type="number" name="actual1"></div>
    <div>Test 4 <input id="actual2" type="number" name="actual2"></div>
  </form>
  <div>&nbsp;</div>
  <!--
    Since our reset button is outside the <form>
    We use the form="" attribute to point to the correct one.
  -->
  <button id="clear-values" type="reset" form="utility-info">Clear Element Data for Tests 1 &amp; 2</button>
</div>

相关问题