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

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

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

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

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

  1. $(function() {
  2. $("#actual").click(function() {
  3. if ($("#actual").is(":checked")) {
  4. $("#utility-info").hide();
  5. $("#actual-utils").show();
  6. } else {
  7. $("#utility-info").show();
  8. $("#actual-utils").hide();
  9. }
  10. });
  11. $("#clear-values").click(function() {
  12. $("#utility-info").html('');
  13. });
  14. });
  1. #actual-utils {
  2. display: none;
  3. }
  4. span {
  5. padding: 10px;
  6. }
  1. <script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
  2. <input type="checkbox" id="actual" name="actual-util-info"> Use actual data
  3. <div>&nbsp;</div>
  4. <div id="energy-info">
  5. <div id="utility-info">
  6. <div>Test 1 <input id="test1" type="number" name="test1"></div>
  7. <div>Test 2 <input id="test2" type="number" name="test2"></div>
  8. </div>
  9. <div id="actual-utils">
  10. <div>Test 3 <input id="actual1" type="number" name="actual1"></div>
  11. <div>Test 4 <input id="actual2" type="number" name="actual2"></div>
  12. </div>
  13. <div>&nbsp;</div>
  14. <button id="clear-values">Clear Element Data for Tests 1 & 2</button>
  15. </div>
nlejzf6q

nlejzf6q1#

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

  1. jQuery($ => {
  2. const $utilityInfo = $('#utility-info');
  3. const $actualUtils = $('#actual-utils');
  4. $('#actual').on('click', e => {
  5. const useActual = e.target.checked;
  6. $utilityInfo.toggle(!useActual);
  7. $actualUtils.toggle(useActual);
  8. });
  9. $('#clear-values').click(function() {
  10. $utilityInfo.find('input').val('');
  11. });
  12. });
  1. #actual-utils {
  2. display: none;
  3. }
  4. span {
  5. padding: 10px;
  6. }
  1. <script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
  2. <input type="checkbox" id="actual" name="actual-util-info"> Use actual data
  3. <div>&nbsp;</div>
  4. <div id="energy-info">
  5. <div id="utility-info">
  6. <div>Test 1 <input id="test1" type="number" name="test1"></div>
  7. <div>Test 2 <input id="test2" type="number" name="test2"></div>
  8. </div>
  9. <div id="actual-utils">
  10. <div>Test 3 <input id="actual1" type="number" name="actual1"></div>
  11. <div>Test 4 <input id="actual2" type="number" name="actual2"></div>
  12. </div>
  13. <div>&nbsp;</div>
  14. <button id="clear-values">Clear Element Data for Tests 1 & 2</button>
  15. </div>
展开查看全部
km0tfn4u

km0tfn4u2#

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

  1. /* Toggle the checkbox to show one form at a time */
  2. #actual:checked ~ * #utility-info,
  3. #actual:not(:checked) ~ * #actual-utils {
  4. display: none;
  5. }
  6. span {
  7. padding: 10px;
  8. }
  1. <input type="checkbox" id="actual" name="actual-util-info"> Use actual data
  2. <div>&nbsp;</div>
  3. <div id="energy-info">
  4. <!-- Wrap in <form> elements -->
  5. <form id="utility-info">
  6. <div>Test 1 <input id="test1" type="number" name="test1"></div>
  7. <div>Test 2 <input id="test2" type="number" name="test2"></div>
  8. </form>
  9. <!-- Wrap in <form> elements -->
  10. <form id="actual-utils">
  11. <div>Test 3 <input id="actual1" type="number" name="actual1"></div>
  12. <div>Test 4 <input id="actual2" type="number" name="actual2"></div>
  13. </form>
  14. <div>&nbsp;</div>
  15. <!--
  16. Since our reset button is outside the <form>
  17. We use the form="" attribute to point to the correct one.
  18. -->
  19. <button id="clear-values" type="reset" form="utility-info">Clear Element Data for Tests 1 &amp; 2</button>
  20. </div>
展开查看全部

相关问题