位置: 编程技术 - 正文

提升jQuery的性能需要做好七件事(jquery升级)

编辑:rootadmin

推荐整理分享提升jQuery的性能需要做好七件事(jquery升级),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:jquery升级,jquery可以实现哪些效果,jquery升级,jqueryui,jquery性能优化,jquery技巧,jquery技术,jquery升级,内容如对您有帮助,希望把文章链接给更多的朋友!

做好七件事帮你提升jQuery的性能,想知道哪几件事情吗?

1. Append Outside of Loops

凡是触及到DOM都是有代价的。如果你向DOM当中附加大量的元素,你会想一次性将它们全部附加进来,而不是分多次进行。当在循环当中附加元素就会产生一个常见的问题。

一个常用的技巧是利用文档片段(document fragment)。在循环的每一次迭代当中,将元素附加到片段而不是DOM元素当中。当循环结束后,将片段附加到DOM元素当中即可。

另一个简单的技巧是在循环的每次迭代当中,持续构建一个字符串。当循环结束后,将DOM元素的HTML设置成该字符串。

当然还有其它一些技巧可以供你尝试。一个名为 jsperf 的站点为测试这些性能提供了一条好的出路。该网站允许你使用基准测试每一个技巧,并将其跨平台的性能测试结果可视化的展现出来。

2. Cache Length During Loops

在for循环当中,不要每次都访问数组的 length 属性;应当事先将其缓存起来。

3. Detach Elements to Work with Them

操作DOM是缓慢的,因此你想尽可能减少对齐进行操作。jQuery在1.4版本当中引入了名为 detach() 的方法来帮助解决这一问题,它允许你在对元素进行操作时,将它们从DOM当中分离出来。

4. Don't Act on Absent Elements

如果你正打算在一个空的选择器上运行大量的代码,jQuery并不会给予任何的提示 -- 它将会继续的执行,就像是没有发生任何的错误。必须由你来验证选择器包含了多少元素。

提升jQuery的性能需要做好七件事(jquery升级)

本指南特别适用于那些当选择器不包含元素时还需要大量的开销的 jQuery UI 部件。

5. Optimize Selectors

选择器的优化和过去比起来并不是那么的重要,因为很多浏览器都实现了 document.querySelectorAll() 方法并且jQuery将选择器的负担转移到了浏览器上面。但是仍然有一些技巧需要铭记在心。

基于ID的选择器

以一个ID作为选择器的开始总是最好的。

采用 .find() 方法的方式将更加的快速,因为第一个选择器已经过处理,而无需通过嘈杂的选择器引擎 -- ID-Only的选择器已使用 document.getElementById() 方法进行处理,之所以快速,是因为它是浏览器的原生方法。

特异性

尽量详细的描述选择器的右侧,对于左侧则应反其道而行之。

尽量在选择器的最右侧使用 tag.class 的形式来描述选择器,而在左侧则尽量只使用 tag 或者 .class 。

避免过度使用特异性

去讨好“DOM”总是有利于提升选择器的性能,因为选择器引擎在搜寻元素时无需进行太多的遍历。

避免使用通用选择器

如果一个选择器明确或暗示它能在不确定的范围内进行匹配将会大大影响性能。

假如你使用 .css() 方法来改变超过个元素的CSS,应当考虑为页面添加一个样式标签作为替代,这样做可以提升将近%的速度。

7. Don't Treat jQuery as a Black Box

标签: jquery升级

本文链接地址:https://www.jiuchutong.com/biancheng/379289.html 转载请保留说明!

上一篇:jQuery 移动端artEditor富文本编辑器(jquery实现移动端)

下一篇:jquery插件EasyUI中form表单提交实例分享(jquery-easyui-1.3.3)

  • 如何查商品税收分类编码
  • 待抵扣进项税的账务处理
  • 建筑企业可以挂靠吗
  • 筹建期的收入要交企业所得税吗
  • 国债利息属于免税吗
  • 小规模纳税人零申报逾期未申报
  • 修缮服务开票项目一览表
  • 合同资产在资产负债表中列入什么项目
  • 公司现金支票取钱需要带什么资料
  • 个体工商户亏损
  • 破产清算收到的实收资本是破产资产吗
  • 冲销上年计提的住房公积金怎么做账
  • 当期软件产品可抵扣进项税额 留抵
  • 专票怎么提交不上去
  • 税务部门罚没收入会计分录
  • 免抵退税额抵减额和不得免征和抵扣税额是一个意思吗
  • 安装属于劳务报酬吗
  • 库存现金清查短款会计分录
  • 领专票需要带什么东西
  • 货币性项目和非货币性项目的区别是什么?如何进行处理?
  • 私募股权投资
  • 建筑劳务预缴税款后怎么申报
  • symtray.exe - symtray是什么进程 有何作用
  • 付给银行的手续费分录
  • php脚本主要用于的三个领域
  • php中this和self的区别
  • 使用mac什么意思
  • 电商新公司值得去吗
  • pdf.js原理
  • 工程项目科目如何设置
  • 购货折让会计分录
  • 违约金的增值税税率
  • 代开发票所需的资料?
  • php zend
  • php判断useragent
  • 全局平均池化(GAP)层
  • react组件框架
  • 未来社区政策支持
  • 大二期末要考试吗
  • 合伙企业个人所得税怎么算
  • 超出python用什么
  • 深入理解jvm第三版pdf百度云
  • 一般纳税人内账考虑税额吗
  • 劳务报酬所得与工资薪金所得纳税的区别
  • 零申报公司注销流程
  • 收到土地使用权转让怎么做账
  • 餐饮充值规则说明
  • 增值税运费发票清单怎么开
  • 生产车间包括什么
  • 应收账款多久收不回来作为坏账
  • 电子承兑汇票做账看哪个日期
  • 关税的计税方式一般可以分为
  • 记账凭证是不是转账凭证
  • 保险发票计入什么科目
  • 飞机票抵扣进项税申报表的填写
  • 营改增 交通运输
  • 工会经费是什么凭证
  • 其他流动资产是
  • 企业收到的应收票据应按什么作为入账金额
  • 浅谈mysql explain中key_len的计算方法
  • mysql绿色版配置
  • windows server 2003 密钥
  • open dhcp server
  • CentOS 5.4+OpenVZ+Vtonf打造VPS服务器的方法
  • bboy.exe进程是病毒吗 bboy进程安全吗
  • windows10推送
  • winxp共享文件
  • SUSE Linux Enterprise Server 设置防火墙开启ssh远程端口的方法
  • win7系统电脑图标不见了
  • 快速掌握阅读题的技巧
  • sqlite3 not found 解决方案
  • attributes.add
  • javascript module
  • unity3d导出fbx文件
  • javascript操作数组的方法
  • js写表格模板
  • 车位办房产证需交多少税
  • 2022河南省地方专项计划分数线
  • 广西电子税务局登陆入口
  • 德清社保局固定电话多少
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设