50个jquery代码片段,这些代码能够给你的javascript项目提供帮助。其中的一些代码段是从jQuery1.4.2才开始支持的做
法,另一些则是真正有用的函数或方法,他们能够帮助你又快又好地把事情完成。这些都是我尽量记住的有着最佳性能的代码段
0. 如何创建嵌套的过滤器:
1 2 3 4 5 | .filter( ":not(:has(.selected))" )
|
1. 如何重用元素搜索
1 2 3 4 5 6 7 8 9 10 | var allItems = $( "div.item" );
var keepList = $( "div#container1 div.item" );
< DIV >class names:
$(formToLookAt + " input:checked" ).each( function () {
keepList = keepList.filter( "." + $( this ).attr( "name" ));
});
< /DIV>
|
2. 任何使用has()来检查某个元素是否包含某个类或是元素:
1 2 3 4 | $( "input" ).has( ".email" ).addClass( "email_icon" );
|
3. 如何使用jQuery来切换样式表
1 2 | $( 'link[media=' screen ']' ).attr( 'href' , 'Alternative.css' );
|
4. 如何限制选择范围(基于优化目的):
1 2 3 4 5 6 | var in_stock = $( '#shopping_cart_items input.is_in_stock' );
|
1 2 3 4 5 | < ul id = "shopping_cart_items" >
< li >< input type = "radio" value = "Item-X" name = "item" class = "is_in_stock" /> Item X</ li >
< li >< input type = "radio" value = "Item-Y" name = "item" class = "3-5_days" /> Item Y</ li >
< li >< input type = "radio" value = "Item-Z" name = "item" class = "unknown" /> Item Z</ li >
</ ul >
|
5. 如何正确地使用ToggleClass:
1 2 3 4 5 6 | a.hasClass( 'blueButton' ) ? a.removeClass( 'blueButton' ) : a.addClass( 'blueButton' );
a.toggleClass( 'blueButton' );
|
6. 如何设置IE特有的功能:
7. 如何使用jQuery来代替一个元素:
1 | $( '#thatdiv' ).replaceWith( 'fnuh' );
|
8. 如何验证某个元素是否为空:
1 2 3 | if ($( '#keks' ).html()) {
}
|
9. 如何从一个未排序的集合中找出某个元素的索引号
1 2 3 | $( "ul > li" ).click( function () {
var index = $( this ).prevAll().length;
});
|
10. 如何把函数绑定到事件上:
1 2 3 | $( '#foo' ).bind( 'click' , function () {
alert( 'User clicked on "foo."' );
});
|
11. 如何追加或是添加html到元素中:
1 | $( '#lal' ).append( 'sometext' );
|
12. 在创建元素时,如何使用对象字面量(literal)来定义属性
1 | var e = $( "" , { href: "#" , class: "a-class another-class" , title: "..." });
|
13. 如何使用多个属性来进行过滤
1 2 3 | var elements = $( '#someid input[type=sometype][value=somevalue]' ).get();
|
14. 如何使用jQuery来预加载图像:
1 2 3 4 5 6 7 | jQuery.preloadImages = function () {
for ( var i = 0; i < arguments.length; i++) {
$( "<img />" ).attr( 'src' , arguments[i]);
}
};
$.preloadImages( 'image1.gif' , '/path/to/image2.png' , 'some/image3.jpg' );
|
15. 如何为任何与选择器相匹配的元素设置事件处理程序:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 | $( 'button.someClass' ).live( 'click' , someFunction);
$( "table" ).each( function (){
$( "td" , this ).live( "hover" , function (){
$( this ).toggleClass( "hover" );
});
});
$( "table" ).delegate( "td" , "hover" , function (){
$( this ).toggleClass( "hover" );
});
|
16. 如何找到一个已经被选中的option元素:
1 | $( '#someElement' ).find( 'option:selected' );
|
17. 如何隐藏一个包含了某个值文本的元素:
1 | $( "p.value:contains('thetextvalue')" ).hide();
|
18. 如果自动滚动到页面中的某区域
1 2 3 4 5 6 7 8 | jQuery.fn.autoscroll = function (selector) {
$( 'html,body' ).animate(
{scrollTop: $(selector).offset().top},
500
};
}
$( '.area_name' ).autoscroll();
|
19. 如何检测各种浏览器:
1 2 3 4 | 检测Safari ( if ( $.browser.safari)),
检测IE6及之后版本 ( if ($.browser.msie && $.browser.version > 6 )),
检测IE6及之前版本 ( if ($.browser.msie && $.browser.version <= 6 )),
检测FireFox 2及之后版本 ( if ($.browser.mozilla && $.browser.version >= '1.8' ))
|
20. 如何替换串中的词
1 2 | var el = $( '#id' );
el.html(el.html().replace(/word/ig, '' ));
|
21. 如何禁用右键单击上下文菜单:
1 2 3 | $(document).bind( 'contextmenu' , function (e){
return false ;
});
|
22. 如何定义一个定制的选择器
1 2 3 4 5 6 7 8 9 | $.expr[ ':' ].mycustomselector = function (element, index, meta, stack){
$( '.someClasses:test' ).doSomething();
|
23. 如何检查某个元素是否存在
1 2 3 | if ($( '#someDiv' ).length) {
}
|
Source: |