`

jQuery 之 用技巧来提高代码质量

阅读更多
http://www.cnblogs.com/analyzer/articles/1732327.html
  jQuery之所以如此流行并被从大公司到个人博客的几乎每个人都广泛使用,是因为它上手和使用相当简单,而且为我们提供了一些人都不知道的相当棒的特性。我认为jQuery的大多数用户更趋向于使用jQuery插件来解决面临的难题,这通常是明智的选择。但是当插件相对于你的需求有一定缺陷的时候,你也许更应该想办法自己来解决,下面来看看这些实用的jQuery技巧,他们肯定会能够派上用场的!

您还可以参考以下JavaScript相关教程及资源:
《10种JavaScript特效实例让你的网站更吸引人》
《300+Jquery, CSS, MooTools 和 JS的导航菜单资源》
《10个非常棒的Ajax及Javascript实例资源网站》
《推荐9款很棒的网页绘制图表JavaScript框架脚本》

1.测试并提升你的jQuery选择器水平

  这个jQuery选择器实验室非常酷,它能在线免费使用,当然你也能下来到本地离线使用。这个测试页面包含复杂的HTML组合字段,然后你能尝试预定义使用各种jQuery选择器。如果这还不够你也可以自定义选择器。

点击上图查看清晰大图

2.测试jQuery包装集是否包含某些元素

  如果你想测试一下某个jQuery包装集中是否包含某些元素,你首先可以尝试使用验证首个元素是否存在:

1
2
3
if($(selector)[0]){...}
// 或者这样
if($(selector).length){...}
来看看这个例子:

1
2
3
4
5
6
7
8
9
10
//例子.如果你的页面有以下html代码
<ul id="shopping_cart_items">
  <li><input class="in_stock" name="item" type="radio" value="Item-X" />Item X</li>
  <li><input class="unknown" name="item" type="radio" value="Item-Y" />Item Y</li>
  <li><input class="in_stock" name="item" type="radio" value="Item-Z" />Item Z</li>
</ul>
<pre escaped="true" lang="javascript">...
//这个if条件将返回true,因为我们有两个
// input域匹配了选择器,所以<statement>代码将会执行
if($('#shopping_cart_items input.in_stock')[0]){<statement>}
3.从jquery.org读取jQuery最新版本

你可以使用这句代码读取jQuery的最新版本的代码文件。

1
<script src="http://code.jquery.com/jquery-latest.js"></script>
你可以使用这个方法来调用最近版本的jQuery框架,当然,你还可以使用下面这个代码从ajax.googleapis.com调用同样的最新版本jQuery:

1
2
<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.3.2/jquery.min.js"
type="text/javascript"></script>
4.存储数据

  使用data方法可以避免在DOM中存储数据,有些前端开发er喜欢使用HTML的属性来存储数据:

1
2
3
$('selector').attr('alt', 'data being stored');
//之后可以这样读取数据:
$('selector').attr('alt');
  使用”alt”属性来作为参数名存储数据其实对于HTML来说是不符合语义的,我们可以使用jQuery的data方法来为页面中的某个元素存储数据:

1
2
3
$('selector').data('参数名', '要存储的数据');
//之后这样取得数据:
$('selector').data('参数');
  这个data方法能让你自己明明数据的参数,更语义更灵活,你可以在页面上的任何元素存储数据信息。如果想了解更多关于data()和removeData()方法的介绍,可以看看jQuery官方讲解

这个方法的经典应用是给input域一个默认值,然后在聚焦的时候清空它:
HTML部分:

1
2
3
4
5
<form id="testform">
<input type="text" class="clear" value="Always cleared" />
<input type="text" class="clear once" value="Cleared only once" />
<input type="text" value="Normal text" />
</form>
JavaSript部分:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
$(function() {
//取出有clear类的input域
//(注: "clear once" 是两个class clear 和 once)
$('#testform input.clear').each(function(){
   //使用data方法存储数据
   $(this).data( "txt", $.trim($(this).val()) );
}).focus(function(){
   // 获得焦点时判断域内的值是否和默认值相同,如果相同则清空
   if ( $.trim($(this).val()) === $(this).data("txt") ) {
     $(this).val("");
   }
}).blur(function(){
   // 为有class clear的域添加blur时间来恢复默认值
   // 但如果class是once则忽略
   if ( $.trim($(this).val()) === "" && !$(this).hasClass("once") ) {
     //Restore saved data
     $(this).val( $(this).data("txt") );
   }
});
});
查看Demo

5.jQuery手册常备身边

  大多数人都很难记住所有的编程细节,即使再好的程序员也会有对某个程序语言的疏忽大意,所以把相关的手册打印出来或随时放在桌面上进行查阅绝对是可以提高编程效率的。
oscarotero jquery 1.3 (壁纸版)


6.在FireBug控制台记录jQuery

  FireBug是我最喜欢用的一个浏览器扩展工具之一,这个工具可以让你快速的在可视化界面中了解当前页面的HTML+CSS+JavaScript,并在该工具下完成即时开发。作为jQuery或JavaScript开发人员,FireFox对于记录你的JavaScript代码也得到支持。

写入FireBug控制台的最简单方式如下:

1
console.log("hello world")


你也可以按照你希望的方式写一些参数:

1
console.log(2,4,6,8,"foo",bar)
你也可以编写一个小扩展来记录jQuery对象到控制台:

1
2
3
4
jQuery.fn.log = function (msg) {
    console.log("%s: %o", msg, this);
    return this;
};
对于这个扩展,你可以直接使用.log()方法来记录当前对象到控制台。

1
2
3
$('#some_div').find('li.source > input:checkbox')
    .log("sources to uncheck")
    .removeAttr("checked");
7.尽可能使用ID选择器

  在使用jQuery之后,你会发现利用class属性来选择DOM元素变得相当简单。尽管如此,还是推荐大家尽量少用class选择器取而代之尽量多使用运行更快的ID选择器(IE浏览器下使用class选择器会在遍历整个DOM树之后返回相符的class包装集)。而ID选择器更快是因为DOM本身就有”天然的”getElementById这个方法,而class并没有。所以如果使用class选择器的话,浏览器会遍历整个DOM,如果你的网页DOM结构足够复杂,这些class选择器足矣把页面拖得越来越慢。让我们看看这段简单的HTML代码:

1
2
3
4
5
6
7
8
<div id="main">
<form method="post" action="/">
  <h2>Selectors in jQuery</h2>
  ...
  ...
  <input class="button" id="main_button" type="submit" value="Submit" />
</form>
</div>
1
2
3
//使用class来调用submit按钮要比使用绝对的ID选择器慢很多
var main_button = $('#main .button');
var main_button = $('#main_button');
8.善于利用jQuery链

  jQuery链不但允许以简洁的方式写出强大的操作,而且提高了开发效率,因为它能够把多个命令应用到包装集,而不必重新计算包装集。从而你不用再这样写了:

1
<li>Description: <input type="text" name="description" value="" /></li>
1
2
3
$('#shopping_cart_items input.text').css('border', '3px dashed yellow');
$('#shopping_cart_items input.text').css('background-color', 'red');
$('#shopping_cart_items input.text').val("text updated");
取而代之你可以使用jQuery链来完成简便的操作:

1
2
3
4
5
6
7
8
9
10
11
var input_text = $('#shopping_cart_items input.text');
input_text.css('border', '3px dashed yellow');
input_text.css('background-color', 'red');
input_text.val("text updated");

//same with chaining:
var input_text = $('#shopping_cart_items input.text');
input_text
.css('border', '3px dashed yellow')
.css('background-color', 'red')
.val("text updated");
9.绑定jQuery函数到$(window).load事件

  大多数jQuery实例或教程都告诉我们绑定我们的jQuery代码到$(document).ready事件。虽然$(document).ready事件在大多数情况下都OK,但是它的解析顺序是在文档准备就绪,单文档中的图片等对象正在下载的时候开始运行的。所以在某些时候使用$(document).ready事件并不一定能达到我们预期的效果,比如一些视觉效果和动画、拖拽、预读取隐藏图片等…通过使用$(window).load事件便可以安全的在整个文档都准备就绪之后再开始运行你期望的代码。

1
2
3
$(window).load(function(){
// 将你希望在页面完全就绪之后运行的代码放在这里
});
10.使用jQuery链来限定选择器,让你的代码更简洁更优雅

  由于JavaScript支持链结构而且支持断行,所以你的代码可以写成下面这样,这个例子先在元素上移除一个class然后在同一个元素上添加另一个class:

1
2
3
$('#shopping_cart_items input.in_stock')
    .removeClass('in_stock')
    .addClass('3-5_days');
如果想让它更简单实用,你可以创建一个支持链结构的jQuery函数:

1
2
3
4
5
$.fn.makeNotInStock = function() {
    return $(this).removeClass('in_stock').addClass('3-5_days');
}

$('#shopping_cart_items input.in_stock').makeNotInStock().log();
11.使用回调函数同步效果

  如果你想确保某个事件或动画效果要在另一个事件运行之后再调用,那你就要使用回调函数了。你可以在这些动画效果后面绑定回调函数:slideDown( speed, [回调] ) ie. $(‘#sliding’).slideDown(’slow’, function(){… 点击这里预览这个例子.

1
2
3
4
5
6
<style>
div.button    { background:#cfd; margin:3px; width:50px;
   text-align:center; float:left; cursor:pointer;
   border:2px outset black; font-weight:bolder; }
#sliding      { display:none; }
</style>
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
$(document).ready(function(){
// 使用jQuery的click事件改变视觉效果,并开启滑动效果
$("div.button").click(function () {
   //div.button 现在看上去是按下的效果
   $(this).css({ borderStyle:"inset", cursor:"wait" });
   //#sliding 现在将渐隐并在完成动作之后开启渐显效果
   //slideup once it completes
   $('#sliding').slideDown('slow', function(){
     $('#sliding').slideUp('slow', function(){
       //渐显效果完成后将会改变按钮的CSS属性
       $('div.button').css({ borderStyle:"outset", cursor:"auto" });
     });
   });
});
});
12.学会使用自定义选择器

  jQuery允许我们在css选择器的基础上定义自定义选择器来让我们的代码更简洁:

1
2
3
4
5
6
7
8
9
10
11
12
$.expr[':'].mycustomselector= function(element, index, meta, stack){
    // element- DOM元素
    // index - 堆栈中当前遍历的索引值
    // meta - 关于你的选择器的数据元
    // stack - 用于遍历所有元素的堆栈

    // 包含当前元素则返回true
    // 不包含当前元素则返回false
};

// 自定义选择器的应用:
$('.someClasses:test').doSomething();
下面让我们来看看一个小例子,我们通过使用自定义选择器来锁定含有”rel”属性的元素集:

1
2
3
4
5
6
7
8
9
10
11
$.expr[':'].withRel = function(element){
  var $this = $(element);
  //仅返回rel属性不为空的元素
  return ($this.attr('rel') != '');
};

$(document).ready(function(){
//自定义选择器的使用很简单,它和其他选择器一样,返回一个元素包装集
//你可以为他使用格式方法,比如下面这样修改它的css样式
$('a:withRel').css('background-color', 'green');
});
1
2
3
4
5
6
7
8
9
10
11
12
13
14
<ul>
  <li>
    <a href="#">without rel</a>
  </li>
  <li>
    <a rel="somerel" href="#">with rel</a>
  </li>
  <li>
    <a rel="" href="#">without rel</a>
  </li>
  <li>
    <a rel="nofollow" href="#">a link with rel</a>
  </li>
</ul>
13.预加载图片

通常使用JavaScript来预加载图片是个相当不错的方法:

1
2
3
4
5
6
7
8
9
10
11
//定义预加载图片列表的函数(有参数)

jQuery.preloadImages = function(){
  //遍历图片
  for(var i = 0; i<arguments.length; i++){
    jQuery("<img>").attr("src", arguments[i]);

  }
}
// 你可以这样使用预加载函数
$.preloadImages("images/logo.png", "images/logo-face.png", "images/mission.png");
14.将你的代码测试完好

  jQuery有一个名为QUnit单元测试框架。编写测试很容易,它能让您可以放心地修改您的代码,并确保它仍然按预期工作。下面是如何工作的:

1
2
3
4
5
6
7
8
9
10
//将测试分成若干模块.
module("Module B");

test("some other test", function() {
  //指定多少个判断语句需要加入测试中.
  expect(2);
 
  equals( true, false, "failing test" );
  equals( true, true, "passing test" );
});
分享到:
评论

相关推荐

    jQuery常见开发技巧详细整理

    在jQuery的开发过程中,掌握一些常见技巧能显著提升开发效率和代码质量。下面是一些详细的jQuery开发...这些技巧在jQuery开发中非常实用,熟练掌握能有效提高代码质量和效率,让开发者编写出更加优雅的JavaScript代码。

    jQuery攻略 源代码

    6. **插件开发**: 学习如何基于jQuery创建自己的插件,扩展其功能,提高代码复用性。 7. **性能优化**: 探讨如何编写高性能的jQuery代码,避免常见性能陷阱。 8. **兼容性问题**: 了解jQuery对不同浏览器的兼容...

    jQuery 技巧

    **jQuery 技巧** jQuery 是一个广泛应用于 web 开发中的 ...熟练掌握 jQuery 技巧,能够让你在网页开发中游刃有余,提高代码质量和开发效率。在实际项目中,不断实践和学习,你会发现 jQuery 的强大之处远不止于此。

    jQuery常用代码片段

    在IT行业中,jQuery是一个广泛使用的JavaScript库,它简化了HTML文档遍历、事件处理、动画制作和Ajax交互等任务。这篇博文"jQuery常用代码片段"很...通过学习和应用这些常用代码片段,开发者可以提升代码质量和效率。

    50个高级jQuery代码开发技巧

    ### 50个高级jQuery代码开发技巧 #### 1. 创建一个嵌套的过滤器 ...以上这些技巧不仅能够帮助开发者更高效地编写 jQuery 代码,还能提高代码的可维护性和可读性。掌握这些技巧对于提升个人技能和项目质量都大有裨益。

    jquery小米官网竖直导航菜单代码

    【jQuery 小米官网竖直导航菜单代码】是一种在网页设计中常见的交互元素,它用于...在实际项目中,确保将CSS、JavaScript和HTML文件组织得井井有条,并利用现代前端框架如Bootstrap或Vue.js来提升开发效率和代码质量。

    锋利的jquery示例代码

    1. **选择器**: jQuery的选择器是其强大之处之一,它允许开发者使用CSS选择器、ID选择器、类选择器等多种方式来选取DOM元素。例如,`$("#elementId")`用于选取ID为`elementId`的元素,而`$(".className")`则可以选取...

    jQuery应用技巧大全

    通过学习和实践以上jQuery应用技巧,开发者不仅能提高代码质量,还能更好地应对项目中的各种需求,为用户提供更加流畅、便捷的交互体验。文档“1.42修改过的”和“新建 50个必备的实用jQuery代码段”提供了具体的...

    jquery技巧总结

    通过掌握以上技巧,你可以更有效地利用jQuery进行Web开发,提高代码质量和效率。不断探索和实践,你将发现jQuery的更多可能性。在实际工作中,结合具体的项目需求,灵活运用这些技巧,将使你的jQuery编程能力更上一...

    jquery技巧总结(转)

    这篇总结将探讨一些实用的 jQuery 技巧,帮助开发者提高效率和代码质量。 1. **选择器的高效使用** - `$(selector)`:基本的选择器,可以是ID、类、标签名等。 - `$(document).ready()`:确保DOM加载完成后执行...

    jQuery使用经验小技巧(推荐)

    在jQuery的开发过程中,掌握一些实用的技巧可以显著提高代码质量和效率。以下是一些关于jQuery使用经验的小技巧,这些技巧可以帮助你编写更加高效、可维护的jQuery插件。 1. **使用闭包封装代码**: 将jQuery插件...

    了解jQuery技巧来提高你的代码

    本文将深入探讨几个实用的jQuery技巧,帮助你提高代码效率和质量。 1. **提升jQuery选择器水平**: jQuery选择器是其强大之处之一,它们允许你高效地定位DOM元素。你可以通过实践和学习jQuery选择器实验室来提升这...

    Aptana Studio 3添加JQuery代码提示

    ### Aptana Studio 3 添加 JQuery 代码...无论是初学者还是经验丰富的开发者,掌握这一技巧都将显著提升你的开发效率和代码质量。记住,实践是最好的老师,不断尝试和探索,你将发现更多Aptana Studio 3的隐藏潜力。

    高效的50个jquery代码块

    【高效使用jQuery】jQuery是一个强大的...以上都是jQuery中常见的实用技巧,熟练掌握它们可以显著提升JavaScript编程的效率和代码质量。在实际开发中,根据项目需求灵活运用这些技巧,可以更好地实现页面交互和效果。

    精通jquery第二版源代码

    《精通jQuery第二版》源代码是一份深入学习...通过深入研究《精通jQuery第二版》的源代码,开发者不仅可以巩固基础,还能了解更高级的用法和最佳实践,从而在实际项目中更加游刃有余地运用jQuery,提高开发质量和效率。

    Jquery应用技巧大全

    ### Jquery应用技巧详解 #### 一、页面元素的引用 在使用JQuery进行Web开发时,一个重要的基础就是能够熟练地引用页面上的各种元素。...掌握这些技巧对于提高Web开发效率和代码质量都非常有帮助。

    50个最值得收藏的jQuery Mobile开发技巧

    再来看@Font-face技巧,它允许在移动应用中使用自定义字体,这对于提高应用界面的美观性和专业度是非常有用的。这种方法比其他字体替换技术,如cufon或sIFR,通常更简单且性能更佳。因此,在移动应用开发过程中考虑...

    《jquery.基础教程》源代码

    3. **Learning jQuery**:这可能是书籍或教程的名称,它可能包含一系列章节,逐步引导读者了解jQuery的基本概念和高级技巧,如使用$(document).ready()方法确保代码在页面加载完成后执行,使用$.ajax()进行异步数据...

    两个超级经典的图片转换代码(jQuery实现的)

    本篇文章将深入探讨两个使用jQuery实现的经典图片转换代码,它们具有极高的实用性和灵活性。 首先,我们来理解什么是图片转换。在网页中,图片转换通常指的是改变图片的显示方式,如更改尺寸、格式、透明度或动态...

    jQuery技巧大放送

    在JavaScript的世界里,jQuery是一个非常流行且强大的库,它极大地...了解并熟练运用这些jQuery技巧,能让你的前端开发工作更加得心应手,提高代码质量和效率。不断学习和实践,将使你在JavaScript开发领域更进一步。

Global site tag (gtag.js) - Google Analytics