返回顶部
首页 > 资讯 > 前端开发 > JavaScript >清空元素html("") innerHTML="" 与 empty()的区别和应用有哪些
  • 500
分享到

清空元素html("") innerHTML="" 与 empty()的区别和应用有哪些

2024-04-02 19:04:59 500人浏览 安东尼
摘要

今天就跟大家聊聊有关清空元素html("") innerHTML="" 与 empty()的区别和应用有哪些,可能很多人都不太了解,为了让大家更加了解,小编给大家总结

今天就跟大家聊聊有关清空元素html("") innerHTML="" 与 empty()的区别和应用有哪些,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。

一、清空元素的区别

     1、错误做法一:

           $("#test").html("");//该做法会导致内存泄露

     2、错误做法二:

           $("#test")[0].innerHTML="";  ;//该做法会导致内存泄露

     3、正确做法:

        //$("#test").empty();       

二、原理:

Jquery 中用 innerHTML 的方法来清空元素,是必然会导致内存泄露的,由于 jquery 对于同一元素多事件处理没有直接采用浏览器事件模型,而是自己缓存事件,遍历触发,以及便于 trigger 程序触发 :

// Init the element's event structure 
 var events = jQuery.data(elem, "events") || jQuery.data(elem, "events", {}), 
  handle = jQuery.data(elem, "handle") || jQuery.data(elem, "handle", function(){ 
  // Handle the second event of a trigger and when 
  // an event is called after a page has unloaded 
  return typeof jQuery !== "undefined" && !jQuery.event.triggered ? 
   jQuery.event.handle.apply(arguments.callee.elem, arguments) : 
   undefined; 
  });

采用 data 方法,将一些数据关联到了元素上面,上述事件即是采用该机制缓存事件监听器。

那么就可以知道,直接 innerHTML=“” 而不通知 jquery 清空与将要删除元素关联的数据,那么这部分数据就再也释放不了了,即为内存泄露。

remove: function( selector ) { 
 if ( !selector || jQuery.filter( selector, [ this ] ).length ) { 
  // Prevent memory leaks 
  jQuery( "*", this ).add([this]).each(function(){ 
  jQuery.event.remove(this); 
  jQuery.removeData(this); 
  }); 
  if (this.parentnode) 
  this.parentNode.removeChild( this ); 
 } 
 }, 
 empty: function() { 
 // Remove element nodes and prevent memory leaks 
 jQuery(this).children().remove(); 
 
 // Remove any remaining nodes 
 while ( this.firstChild ) 
  this.removeChild( this.firstChild ); 
 }

看完上述内容,你们对清空元素html("") innerHTML="" 与 empty()的区别和应用有哪些有进一步的了解吗?如果还想了解更多知识或者相关内容,请关注编程网JavaScript频道,感谢大家的支持。

--结束END--

本文标题: 清空元素html("") innerHTML="" 与 empty()的区别和应用有哪些

本文链接: https://lsjlt.com/news/81276.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • 清空元素html("") innerHTML="" 与 empty()的区别和应用有哪些
    今天就跟大家聊聊有关清空元素html("") innerHTML="" 与 empty()的区别和应用有哪些,可能很多人都不太了解,为了让大家更加了解,小编给大家总结...
    99+
    2024-04-02
  • 字符串 len == 0 和 字符串== "" 的区别有哪些
    这篇文章主要讲解了“字符串 len == 0 和 字符串== "" 的区别有哪些”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“字符串 len == 0 和 字符串== &...
    99+
    2023-06-15
  • HTML中行内元素和块级元素的区别有哪些
    本文将为大家详细介绍“HTML中行内元素和块级元素的区别有哪些”,内容步骤清晰详细,细节处理妥当,而小编每天都会更新不同的知识点,希望这篇“HTML中行内元素和块级元素的区别有哪些”能够给你意想不到的收获,请大家跟着小编的思路慢慢深入,具体...
    99+
    2023-06-06
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作