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