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) {
}
|
24. 如何使用jQuery来检测右键和左键的鼠标单击两种情况:
1 2 3 4 5 6 7 | $( "#someelement" ).live( 'click' , function (e) {
if ( (!$.browser.msie && e.button == 0) || ($.browser.msie && e.button == 1) ) {
alert( "Left Mouse Button Clicked" );
} else if (e.button == 2) {
alert( "Right Mouse Button Clicked" );
}
});
|
25. 如何显示或是删除input域中的默认值
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 | wap_val = [];
$( ".swap" ). each ( function (i){
wap_val[i] = $( this ).val();
$( this ).focusin( function (){
if ($( this ).val() == swap_val[i]) {
$( this ).val( "" );
}
}).focusout( function (){
if ($.trim($( this ).val()) == "" ) {
$( this ).val(swap_val[i]);
}
});
});
|
1 | <input type= "text" value= "Enter Username here.." class = "swap" />
|
26. 如何在一段时间之后自动隐藏或关闭元素(支持1.4版本):
1 2 3 4 5 6 | setTimeout( function () {
$( '.mydiv' ).hide( 'blind' , {}, 500)
}, 5000);
$( ".mydiv" ).delay(5000).hide( 'blind' , {}, 500);
|
27. 如何把已创建的元素动态地添加到DOM中:
1 2 | var newDiv = $( '' );
newDiv.attr( 'id' , 'myNewDiv' ).appendTo( 'body' );
|
28. 如何限制"Text-Area”域中的字符的个数:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 | jQuery.fn.maxLength = function (max){
this .each( function (){
var type = this .tagName.toLowerCase();
var inputType = this .type? this .type.toLowerCase() : null ;
if (type == "input" && inputType == "text" || inputType == "password" ){
this .maxLength = max;
}
else if (type == "textarea" ){
this .onkeypress = function (e){
var ob = e || event;
var keyCode = ob.keyCode;
var hasSelection = document.selection? document.selection.createRange().text.length > 0 : this .selectionStart != this .selectionEnd;
return !( this .value.length
>= max && (keyCode > 50 || keyCode == 32 || keyCode == 0
|| keyCode == 13) && !ob.ctrlKey && !ob.altKey
&& !hasSelection);
};
this .onkeyup = function (){
if ( this .value.length > max){
this .value = this .value.substring(0,max);
}
};
}
});
};
$( '#mytextarea' ).maxLength(500);
|
Source: |