阅读更多

13顶
2踩

Web前端

原创新闻 怎么才能书写高质量jQuery代码

2014-09-04 15:03 by 见习记者 huoquan 评论(5) 有10723人浏览

众所周知,jQuery现在已经非常流行,百度新首页中也已经开始使用jQuery,今天总结下怎么书写更好的jQuery代码使jQuery代码更好、更快的执行,希望本篇jQuery教程一改大家以前不合理的做法。

 

1.正确引用jQuery

  1. 尽量在body结束前才引入jQuery,而不是在head中。

  2. 借助第三方提供的CDN来引入jQuery,同时注意当使用第三方CDN出现问题时,要引入本地的jQuery文件。

  3. 如果在</body>前引入script文件的话,就不用写document.ready了,因为这时执行js代码时DOM已经加载完毕了。

    <body>
        <script src="http://lib.sinaapp.com/js/jquery11/1.8/jquery.min.js"></script>
        <script>window.jQuery || document.write('<script src="jquery1.8.min.js">\x3C/script>')</script>
    </body>

     2.优化jQuery选择器

高效正确的使用jQuery选择器是熟练使用jQuery的基础,而掌握jQuery选择器需要一定的时间积累,我们开始学习jQuery时就应该注意选择器的使用。

 

<div id="nav" class="nav">
    <a class="home" href="http://www.jquery001.com">jQuery学习网</a>
    <a class="articles" href="http://www.jquery001.com/articles/">jQuery教程</a>
</div>

如果我们选择class为home的a元素时,可以使用下边代码:

$('.home');  //1
$('#nav a.home');  //2
$('#nav').find('a.home');  //3

 

方法1会使jQuery在整个DOM中查找class为home的a元素,性能可想而知。

  1. 方法2为要查找的元素添加了上下文,在这里变为查找id为nav的子元素,查找性能得到了很大提升。

  2. 方法3使用了find方法,它的速度更快,所以方法三最好。

  3. 关于jQuery选择器的性能优先级,ID选择器快于元素选择器,元素选择器快于class选择器。因为ID选择器和元素选择器是原生的JavaScript操作,而类选择器不是,大家顺便可以看下find context 区别,find() children区别。

3.缓存jQuery对象

缓存jQuery对象可以减少不必要的DOM查找,关于这点大家可以参考下缓存jQuery对象来提高性能。

4.正确使用事件委托

事件委托可以使事件更好的执行,在动态添加的元素上绑定事件也需要委托来实现,在新版本的jQuery中推荐大家使用on来给元素绑定一个或多个事件的处理函数。

<table id="t">
    <tr>
        <td>我是单元格</td>
    </tr>
</table>

比如我们要在上边的单元格上绑定一个单击事件,不注意的朋友可能随手写成下边的样子:

$('#t').find('td').on('click', function () {
    $(this).css({ 'color': 'red', 'background': 'yellow' });
});

 这样会为每个td绑上事件,在为100个单元格绑定click事件的测试中,两者性能相差7倍之多,好的做法应该是下边写法:

$('#t').on('click', 'td', function () {
    $(this).css({ 'color': 'red', 'background': 'yellow' });
});

 5.精简jQuery代码

如在上述代码中我们对jQuery代码进行了适当的合并,类似的还有.attr()方法等,我们没有写成下边的方式:

$('#t').on('click', 'td', function () {
    $(this).css('color', 'red').css('background', 'yellow');
});

 6.减少DOM操作

刚开始使用jQuery时可能会频繁的操作DOM,这是相当耗费性能的。如我们要在body中动态输出一个表格,一些朋友会这样写:

var $t = $('body');
$t.append('<table>');
$t.append('<tr><td>1</td></tr>');
$t.append('</table>');

 好的做法:

$('body').append('<table><tr><td>1</td></tr></table>');

这样在拼接完table串后再添加到body中,对DOM的操作只需一次。群里以前有朋友就因为这个导致在IE下输出时出现问题,而关于字符串的拼接可以参考下最快创建字符串的方法。

7.不使用jQuery

原生函数总是最快的,这点不难理解,在代码书写中我们不应该忘记原生JS。

就先总结这几条吧,每条建议并不难理解,但总结全面的话还是要花费不少时间的。如在减少代码段中,如果需要根据条件从数组中得到新数组时,可以使用$.grep() 方法,如果你在使用jQuery时有自己心得的话,欢迎在留言中和大家分享!

13
2
评论 共 5 条 请登录后发表评论
5 楼 bossdai 2014-09-10 09:47
yandou524 写道
根据css加载原理,jquery选择器的选择应该层数越少越好吧

4 楼 terencewong 2014-09-09 14:14
CDN 会有很多的优化,比如说基于地理位置的,和fail over.举个例子
比如你的服务器在北京,用户在上海,如果你用CDN,上海的CDN就会响应用户请求,当然会比你北京的服务器发送好的多.当然,如果CDN有问题 你可以退回到本地JS.
Night舞夜 写道
"借助第三方提供的CDN来引入jQuery,同时注意当使用第三方CDN出现问题时,要引入本地的jQuery文件。"

我想问一下,既然还是要判断引入本地的js。为何还引入第三方js。直接引入本地不就好了么?

3 楼 Night舞夜 2014-09-09 11:58
"借助第三方提供的CDN来引入jQuery,同时注意当使用第三方CDN出现问题时,要引入本地的jQuery文件。"

我想问一下,既然还是要判断引入本地的js。为何还引入第三方js。直接引入本地不就好了么?
2 楼 chen243048349 2014-09-09 10:53
.find() 和 .children() 方法类似,不过后者只沿着 DOM 树向下遍历单一层级
1 楼 yandou524 2014-09-04 19:04
根据css加载原理,jquery选择器的选择应该层数越少越好吧

发表评论

您还没有登录,请您登录后再发表评论

相关推荐

  • 如何书写高质量的jQuery代码

    如何书写高质量的jQuery代码想必大家对于jQuery这个最流行的javascript类库都不陌生,而且只要是前端开发人员肯定或多或少的使用或者接触过,在今天的这篇文章中,我们将介绍一些书写高质量jQuery代码的原则,我们不...

  • 如何书写高质量jQuery代码(使用jquery性能问题)

    众所周知,jQuery现在已经非常流行,百度新首页中也已经开始使用jQuery,今天总结下怎么书写更好的jQuery代码使jQuery代码更好、更快的执行,希望本篇jQuery教程一改大家以前不合理的做法

  • 书写高质量jQuery代码的12条经验

    1、正确引用jQuery 尽量在body结束前才引入jQuery,而不是在head中。...如果在前引入script文件的话,就不用写document.ready了,因为这时执行js代码时DOM已经加载完毕了。 src="//lib.sinaapp.com/js/jque

  • php培训经验如何写,书写高质量jQuery代码的6条经验

    如何才能书写出高质量的jQuery代码,困扰这不少人,不知何从下手。今天合肥达内PHP培训为大家总结的6条经验,拿走不谢!一、正确引用jQuery尽量在body结束前才引入jQuery,而不是在head中。借助第三方提供的CDN来...

  • 怎么书写高质量jQuery代码

    众所周知,jQuery现在已经非常流行,百度新首页中也已经开始使用jQuery,今天总结下怎么书写更好的jQuery代码使jQuery代码更好、更快的执行,希望本篇jQuery教程一改大家以前不合理的做法。   1.正确引用jQuery ...

  • 怎么书写高质量jQuery代码【收藏】

    众所周知,jQuery现在已经非常流行,百度新首页中也已经开始使用jQuery,今天总结下怎么书写更好的jQuery代码使jQuery代码更好、更快的执行,希望本篇jQuery教程一改大家以前不合理的做法。 ...

  • 书写高质量jQuery代码

    1、正确引用jQuery (1)、 尽量在body结束前才引入jQuery,而不是在head中。 (2)、 借助第三方提供的CDN来...前引入script文件的话,就不用写document.ready了,因为这时执行js代码时DOM已经加载 完毕了。 ...

  • 书写高质量的jQuery代码

    在jQuery代码开发中,我们常常需要操作DOM,DOM操作是非常消耗资源的一个过程,而往往很多人都喜欢这样使用jQuery: $ ( '#loading' ). html ( '完毕' ); $ ( '#loading' ). ...

  • 基于MRAS的感应电机无速度传感器矢量控制及速度估计技术解析

    内容概要:本文深入探讨了利用模型参考自适应系统(MRAS)实现感应电机无速度传感器矢量控制的方法。重点介绍了MRAS的工作原理,即通过电压模型作为参考模型,电流模型作为可调模型,在线比较两者输出误差并进行自适应调整,从而实现精确的速度估计。文中详细解释了关键代码实现,包括自适应律的设计、参数选择以及针对突加载工况的优化措施。同时讨论了实际应用中的调试技巧和注意事项,如积分饱和处理、参数辨识等问题。测试结果显示,相比传统方法,MRAS方案在突加载情况下表现出更好的鲁棒性和更快的响应速度。 适合人群:从事电机控制系统研究与开发的技术人员,尤其是关注无速度传感器矢量控制领域的工程师。 使用场景及目标:适用于需要提高感应电机控制系统性能的应用场合,特别是在无法安装物理速度传感器的情况下,通过软件算法实现高精度的速度估计。主要目标是降低硬件成本,增强系统的可靠性和环境适应性。 其他说明:文中提供了丰富的实验数据支持结论,并引用多篇权威文献作为理论依据。对于希望深入了解MRAS技术原理及其工程应用的读者来说,是一份非常有价值的参考资料。

  • 基于FPGA的AM调制解调全流程实现与优化

    内容概要:本文详细介绍了基于FPGA实现AM调制解调的全过程,涵盖从Matlab滤波器设计到Verilog代码实现,再到最终硬件测试的各个环节。首先,文章讲解了发射端的设计,包括载波生成和调制方法,采用DDS技术和定点运算提高效率。接着,深入探讨了接收端的关键技术,尤其是FIR滤波器的手工实现及其优化措施。文中还分享了许多实践经验,如时钟同步、数据位宽处理以及如何避免常见错误。最后,作者提供了完整的工程代码,并强调了动手实现而非调用IP核所带来的深刻理解和宝贵经验。 适合人群:具有一定FPGA开发基础的技术人员,尤其是对通信系统感兴趣的电子工程师。 使用场景及目标:适用于希望深入了解AM调制解调机制并在FPGA平台上进行相关实验的研究人员和技术爱好者。目标是掌握AM调制解调的具体实现步骤,理解各部分的工作原理,并能够独立完成类似项目的开发。 其他说明:文章不仅提供了详细的理论解释和技术细节,还包括了大量的实战经验和调试技巧,帮助读者更好地理解和应用所学知识。同时,所有源代码均已公开,方便读者下载学习。

  • BMS电池管理控制器开发板及其应用层软件开发全流程详解

    内容概要:本文详细介绍了BMS(电池管理系统)电池管理控制器开发板的相关内容,涵盖硬件部分的关键模块如电压采集模块、电流采集模块等,以及电池管理系统策略开发,包括充电策略、放电策略、电池均衡策略等。同时探讨了应用层软件的开发流程,从需求分析、架构设计、代码实现到最后的测试与优化,提供了丰富的实战经验和代码示例。此外,文中还涉及了一些具体的开发细节和技术难点,如ADC采样电路设计、SOC估算算法、HIL测试、故障注入测试等。 适合人群:从事电池管理系统开发的技术人员,尤其是有一定硬件和软件开发基础的研发人员。 使用场景及目标:适用于希望深入了解BMS开发板硬件设计、掌握电池管理系统策略制定方法、熟悉应用层软件开发流程的专业人士。目标是在实际项目中能够独立完成BMS系统的开发与优化。 其他说明:文中不仅提供了理论知识,还结合了大量的实战案例和代码片段,帮助读者更好地理解和应用相关技术。

  • 电力电子领域单相三电平NPC逆变器的载波层叠技术及SVPWM与SPWM调制策略解析

    内容概要:本文深入探讨了单相三电平NPC(Neutral Point Clamped)逆变器的技术特点及其主要调制策略。首先介绍了载波层叠技术,这是一种通过多个载波信号实现对逆变器输出电平精确控制的方法。接着分别讲解了SVPWM(空间矢量脉宽调制)和SPWM(正弦脉宽调制)这两种不同的调制方式,前者以电机磁链圆形旋转为目标,后者则是通过正弦波与三角波比较来决定输出电平。文中还提供了具体的C语言、Python和MATLAB代码示例,帮助读者更好地理解和实现这些调制方法。此外,文章讨论了不同调制方式之间的优缺点,并给出了实际应用场景的选择建议。 适合人群:从事电力电子研究的专业人士,尤其是那些希望深入了解单相三电平NPC逆变器及其调制策略的研究人员和技术人员。 使用场景及目标:适用于需要优化逆变器性能的设计项目,如工业自动化设备、新能源发电系统等。目标是在确保高效能的同时减少谐波失真,提高系统的稳定性和可靠性。 其他说明:文中引用了一些权威书籍和学术期刊作为参考资料,鼓励有兴趣进一步探索的读者查阅相关文献。同时强调了在实际应用中要考虑的因素,比如开关损耗、中性点电压平衡等问题。

  • COMSOL模拟超声清洗中28kHz压电片厚度与分布对声场强度影响的研究

    内容概要:本文详细探讨了利用COMSOL软件进行超声清洗模拟过程中,28kHz压电片的厚度和分布对声场强度的影响。研究表明,压电片的厚度变化显著影响声场强度,较薄的压电片能产生更强的声场。此外,压电片的不同分布方式也会导致声场分布的变化,均匀分布的压电片能使声场更加均匀,而集中分布则在某些区域产生更强的声场。文中还介绍了建模的关键步骤,包括物理场的选择、边界条件的设定以及网格划分的方法,并强调了考虑水的声阻尼和其他环境因素的重要性。 适合人群:从事超声清洗设备设计、优化及相关研究的技术人员和科研工作者。 使用场景及目标:①帮助研究人员理解压电片厚度和分布对声场强度的具体影响;②提供详细的建模方法和注意事项,以便更好地优化超声清洗设备的设计;③指导实际应用中如何选择合适的压电片参数以达到最佳清洗效果。 其他说明:文中提供了多个具体的MATLAB和COMSOL代码片段,用于展示如何在模拟中调整压电片参数并验证其对声场强度的影响。同时,作者分享了许多实践经验,指出了常见的错误和需要注意的地方。

  • 电力电子领域级联H桥与电能质量控制技术的应用及优化

    内容概要:本文深入探讨了级联H桥在电力电子领域的应用及其相关控制技术。首先介绍了级联H桥的基本概念及其在STATCOM、APF、PCS、SVG等设备中的重要作用。随后详细讲解了几种关键控制策略,包括双闭环控制、自抗扰控制、重复控制、调制与均衡控制等,并通过具体实例展示了这些控制策略的实际应用效果。此外,文章还讨论了在不平衡电网环境下的控制挑战及解决方案,如正负序解耦控制、负序补偿等。最后分享了一些实际调试经验和技巧,强调了控制策略优化对提升电力系统性能的关键作用。 适合人群:从事电力电子研究和技术开发的专业人士,尤其是对级联H桥及相关控制技术感兴趣的工程师。 使用场景及目标:适用于需要深入了解级联H桥工作原理及其控制策略的研究人员和技术人员,旨在帮助他们掌握先进的控制技术和调试方法,从而提高电力系统的稳定性、可靠性和效率。 其他说明:文中提供了大量代码片段作为理论支持,便于读者理解和实践。同时,作者结合自身丰富的工程经验,分享了许多实用的调试技巧和注意事项。

  • 基于PLC的3×4立体车库系统设计:12车位共享载车板的自动化存取解决方案

    内容概要:本文详细介绍了基于PLC(西门子S7-1200)的3×4布局立体车库系统设计。该系统通过一个载车板实现12个车位的存取,采用伺服电机和步进电机进行升降和平移操作,配备光电开关、急停按钮等多种安全措施。文中展示了具体的梯形图和ST语言代码片段,解释了存取车流程、安全联锁机制以及调试过程中遇到的问题及其解决方案。此外,还讨论了系统的扩展性和未来可能的技术改进方向。 适合人群:从事自动化控制系统设计、PLC编程的专业人士,以及对立体车库系统感兴趣的工程师和技术爱好者。 使用场景及目标:适用于城市停车难区域,特别是老城区和商铺密集区。目标是提高停车场的空间利用率,缩短存取车时间,增强安全性并降低成本。 其他说明:文中不仅提供了详细的硬件配置和软件实现方法,还包括了许多实际调试经验和技巧,如电机启停惯性的处理、信号滤波电路的应用等。这些经验对于理解和实施类似项目非常有价值。

  • FPGA数据采集系统的构建与优化:AD7606、RTL8211、SD卡及串口通信的综合应用

    内容概要:本文详细介绍了基于FPGA的数据采集系统的设计与实现,涵盖了四个主要模块:AD7606模数转换、RTL8211千兆以太网、SD卡存储以及串口通信。文章首先讲解了AD7606的Verilog状态机控制逻辑,确保精确的时序控制以获取高质量的模拟信号。接着讨论了RTL8211千兆网卡的配置,特别是RGMII接口与时钟延迟调整,确保稳定的网络传输。对于SD卡存储,文章提供了详细的初始化流程和扇区写入方法,解决了常见的文件系统崩溃问题。最后,串口通信部分展示了如何通过状态机实现高效的命令解析和数据传输。文中还分享了许多实战经验和常见问题的解决方案,如时序偏差、数据完整性和硬件兼容性等问题。 适合人群:具有一定FPGA开发经验的工程师和技术爱好者,尤其是从事工业自动化、数据采集和嵌入式系统开发的专业人士。 使用场景及目标:适用于需要高性能数据采集和传输的应用场合,如工业监控、实验数据分析等。目标是帮助读者掌握如何从零搭建一个稳定可靠的FPGA数据采集系统,提高数据处理效率和可靠性。 其他说明:文章不仅提供具体的代码实现,还强调了系统集成过程中可能遇到的实际挑战及其应对措施,有助于读者更好地理解和应用相关技术。

  • LCD1602和AD0809源码

    LCD1602和AD0809源码

  • 光伏系统中电导增量法MPPT算法的优化与仿真实现

    内容概要:本文详细介绍了电导增量法(INC)在光伏发电系统中的最大功率点跟踪(MPPT)算法。首先解释了INC算法的核心逻辑,即通过电导变化量判断爬山方向,并讨论了关键参数如阈值、步长的选择及其对系统稳定性的影响。接着探讨了PWM调制的具体实现方式,强调了V_pv_max的实时获取重要性和自适应步长策略的应用。此外,还分享了一些实用的仿真技巧,如加入噪声处理、动态调整I-V曲线以及使用卡尔曼滤波提高跟踪精度。最后,通过实验数据验证了改进后的INC算法在不同光照条件下的优越性能。 适合人群:从事光伏系统研究与开发的技术人员,尤其是对MPPT算法感兴趣的工程师。 使用场景及目标:适用于需要深入了解和优化光伏系统MPPT算法的研究和开发工作,旨在提升光伏系统的能量转换效率。 其他说明:文中提供了大量代码片段和实践经验,帮助读者更好地理解和应用电导增量法。同时提醒读者关注一些常见的陷阱和技术细节,确保仿真的准确性和可靠性。

  • 基于动态规划的燃料电池混合动力系统能量管理策略及其MATLAB实现

    内容概要:本文探讨了基于动态规划(DP)的燃料电池混合动力系统能量管理策略,并详细介绍了在MATLAB平台上的具体实现。文中强调了严格控制电池荷电状态(SOC)始末值一致性的必要性,这是为了确保电池寿命和系统稳定性。通过动态规划算法,能够从全局最优角度规划能量分配,同时考虑了动力系统性能衰退的因素。文章提供了详细的代码示例,解释了如何根据不同的工况调整功率需求序列,以适应城市拥堵、高速巡航等多种情况。此外,还讨论了目标函数设计中的创新点,如引入燃料电池效率衰减因子,以及如何通过状态网格化处理精确控制SOC。 适合人群:从事燃料电池混合动力系统研究的技术人员、研究人员和高校师生。 使用场景及目标:适用于需要优化燃料电池混合动力系统能量管理的研究项目,旨在提高系统效率、延长组件寿命,并确保SOC始末值的一致性。目标是为相关领域的研究提供理论支持和技术指导。 其他说明:文章不仅提供了完整的代码实现,还深入解析了每一步骤背后的原理,帮助读者更好地理解和应用动态规划算法于实际问题中。

  • texlive-beamer-7:20180414-23.el8.x64-86.rpm.tar.gz

    1、文件说明: Centos8操作系统texlive-beamer-7:20180414-23.el8.rpm以及相关依赖,全打包为一个tar.gz压缩包 2、安装指令: #Step1、解压 tar -zxvf texlive-beamer-7:20180414-23.el8.tar.gz #Step2、进入解压后的目录,执行安装 sudo rpm -ivh *.rpm

Global site tag (gtag.js) - Google Analytics