| 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: |