使用JQuery的9个误区
作者:夜飞羽 来源:mxria.com 时间:2012-05-16
JQuery是如此容易使用以至于我们有时候忘记了CSS的存在。我们在使用CSS时,几乎不去考虑性能,因为它已经是快得不值得再去做什么优化上的努力。但现实世界中,JQuery会导致令开发人员发疯的性能问题。有时你会毫无知觉地就损失那么几毫秒。我们也很容易忘记的一些功能并继续使用一些旧的(和不那么好的)的功能。以下是使用JQuery过程容易犯的9个错误,看看是不是你也曾遇到过?
1.不使用最新的版本
如今的稳定版本是1.7.2,你看看你的机器是不是最新的?可能你不会把已经做好的网站再去更新一把,毕竟这个工作量可能没人给你付费,但新的开发项目呢?千万别忘记了使用最新的版本哦,毕竟每个版本更新肯定会在功能或性能上有所提升,或者修复了几个Bug,但有时惰性让人不想再去研究新版本的变化,因此,提醒你别忘记了在新项目用新的一定比旧版本要好。
2.不使用CDN-hosted的JQuery
很多人喜欢Download到自己的服务器上,然后调用。似乎潜意识里文件放在自己手里比较有安全感。但大部分时候,除非你特别牛,自己的服务器比不过CDN服务器。如果流量小,可能没有什么影响,但如果流量一旦大了,性能方面的影响就非常突出了,这时,你完全可以考虑CDN服务器嘛,比如google的Copy,这对于网站的性能有很大的帮助!
你只需要调用时采用如下:
1
|
<script type= "text/javascript" src= "//ajax.googleapis.com/ajax/libs/jquery/1.7.2/jquery.min.js" ></script>
|
3.使用了CDN-hosted版本但没有备份措施
尽管我们相信Google很牛逼,不会出问题,但别忘记了你在天朝,一切皆有可能!因此,在html代码中加上本地服务器版本的容灾计划还是很有必要的,也非常简单:
1
2
3
|
<script src= "//ajax.googleapis.com/ajax/libs/jquery/1.7.2/jquery.min.js" ></script>
<script>window.jQuery || document.write( '<script src="js/libs/jquery-1.7.2.min.js"><\/script>' )</script>
|
4. 忘记链式写法
我们在进行一些普通操作时,如果多使用链式操作方式,可以提高性能,不用多次加载元素。例如
1
2
3
4
5
6
7
|
$(“ #mydiv”).hide();
$(“ #mydiv”).css(“padding-left”, “50px”);
JQuery会获取元素2次
$(“ #mydiv”).hide().css(“padding-left”, “50px”);
|
一次搞定,有时候链式写法带来的性能改善是相当可观的哦
5.忘记缓存
这是跟性能相关的重要提示:别忘记缓存!如果页面中调用了某个元素至少2次,你就应该考虑缓存了。通过一个变量就可以在JQuery中缓存选择器。当第二次使用该选择器时,只需引用该变量即可。这样做的好处就是JQuery不用再次遍历搜索整个DOM树去寻找你选择的元素。例如
1
2
3
4
|
var $myMxria = $(“ #mydiv”).hide();
$myMxria.show();
|
6.干嘛不使用原始的JS?
用惯了$,大家就基本忽略document.getElementById了,但不得不说,滥用$也是不对的,为什么呢?如果只是纯粹的属性修改,使用原始的javascript性能更好,完全没有使用JQuery对象。例如下面的例子中,浏览器还是会将JQuery对象转化为DOM节点进行操作。
1
|
$mydiv[0].setAttribute( 'class' , 'awesome' );
|
7.未作检查的滥用插件
如今,JQuery流行起来也带来无数插件,精彩的、雷人的各种插件很多。我们很喜欢追随潮流,用些时髦玩意儿。但事实上,很多插件需要我们认真评估,看看到底是不是适合你的项目,或者说你真的需要吗?有没有考虑以下因素呢?
- 文件大小:超过10k的大小就得反复考虑一下哦
- 性能评估:图个方便不在乎性能?真的吗?
- 跨浏览器支持: 看看你的客户在用什么浏览器,别忘记了古老的IE6可是依然风采依旧哦
- 移动支持: 确认插件是可以在Mobile环境下运作正常的
8 不用JQuery
不用不行吗?干嘛一定要用呢?很多时候我们可能根本没有想过这个问题,首先想到的可能是用Jquey好像很容易实现啊!这个误区真的很普遍,你有一把快刀砍到底的习惯吗?
9 使用JQuery干服务器端的活
JQuery太好了,太强大了,似乎一切都可以在前端搞定!于是,我们又会进入一个误区:类似有效性检查和数据验证的活,忽略了在服务端的重要性。很多业务逻辑能在前端处理的就一古脑在前端处理,过犹不及的悲剧就此发生!千万要记住,前端浏览器里啥事都可能发生!!!禁用JS、某个不兼容问题、伪造数据、攻击行为,这些都不是开发者能100%掌控到的,所以,服务端的活千万别因为JQuery的强大而放松警惕!
以上供参考,看看你有无走进误区?
分享到:
相关推荐
jQuery验证框架学习教程详细介绍了jQuery及其验证插件的使用方法,旨在帮助开发者快速掌握jQuery这一强大的JavaScript库,并学会如何使用其提供的验证功能来增强Web应用的用户交互体验。 首先,jQuery是一个开源的...
jQuery 是一个广泛使用的 JavaScript 库,它为开发者提供了一系列强大且简洁的功能,使得网页交互和动态效果的实现变得更加容易。本教程适合初学者,特别是那些有一定 JavaScript 基础但尚未接触过 jQuery 的朋友们...
jQuery是一个被广泛使用的轻量级脚本库,它简化了JavaScript编程,提高了开发效率,尤其在处理浏览器兼容性和实现丰富的用户界面(UI)效果方面表现出色。 1. **jQuery的定义**:jQuery是一个集合了众多工具方法和...
为了让大家更好地理解如何使用jQuery,接下来将通过一个简单的“Hello World”示例来展示如何编写第一个jQuery程序。 1. **引入jQuery库:** 首先需要在HTML文件中引入jQuery库。可以通过CDN链接直接引入,也可以...
- 纠正脚本知识误区:jQuery 教育开发者正确使用 JavaScript,比如避免在 DOM 加载前操作 DOM,正确理解和使用事件处理等。 6. **jQuery 实战** - jQuery 动画:如使用 `.animate()` 方法实现自定义动画效果,...
示例代码中指出了一个常见的误区,即错误地判断`$("#id").attr("checked")=="true"`。正确的判断方式应该是`$("#id").attr("checked")==true`,因为`.attr("checked")`返回的是一个属性字符串,而不是布尔值。 示例...
JQuery中的toggle()函数是jQuery库中一个非常实用的动画方法,它用于切换元素的显示状态。当你调用这个方法时,如果元素当前是隐藏的,它将会被显示出来;如果元素是可见的,它将被隐藏。这个方法既可以通过直接调...
jQuery EasyUI 是一个基于 jQuery 的前端框架,专为简化企业级开发而设计。它提供了一系列的JavaScript组件,可以帮助开发者快速构建用户界面,无需深入理解复杂的前端技术。EasyUI 的优势在于其出色的兼容性和高度...
转化的例子中,有一个常见的误区是关于`this`关键字的使用。在JavaScript中,`this`的值取决于它所在的上下文。在jQuery事件处理函数中,`this`通常指向触发事件的DOM元素。如果尝试直接在`this`上调用jQuery方法,...
误区: 以前一直以为jquery获取select中option被选中的文本值,是这样写的: 复制代码 代码如下:$(“#s”).text(); //获取所有option的文本值 实际上应该这样: 复制代码 代码如下:$(“#s option:selected”).text()...
在使用这些方法时,我们还需要注意一个常见的误区,那就是$(document).width()和$(window).width()在某些情况下可能会返回不一样的值。通常情况下,它们都应该返回同样的结果,除非页面内容超出了视口尺寸,或者页面...
本文实例讲述了jquery淡入淡出效果实现方法。分享给大家供大家参考,具体如下: 之前理解有一些误区,以为淡入淡出是删除该元素,其实只是把该元素隐藏起来 和 显示出来罢了。 具体代码如下: <!DOCTYPE ...
在探讨Ext JS添加子组件的误区时,首要问题是许多人倾向于在渲染子组件时将Grid渲染到容器内的一个div元素中。这种做法虽然看起来方便,但往往会导致后续布局调整的问题。在Ext JS框架中,布局是通过控制容器的直接...
初学者常常会陷入一个误区,他们过分专注于理论知识,大量阅读编程书籍,寄希望于通过理论来完全掌握编程。然而,编程是一项实践性很强的技术,理论知识若不通过实践是很难被真正掌握的。正确的学习方法应该是将理论...
以下是一个使用Renderer2操作DOM的示例代码: ```typescript import { Component, ElementRef, Renderer2, ViewChild, OnInit, AfterViewInit } from '@angular/core'; @Component({ selector: 'app-product', ...