乐趣区

几个非常实用的JQuery代码片段

jQuery 是一个兼容多浏览器的 javascript 库,核心理念是 write less,do more(写得更少, 做得更多)。jQuery 使用户能更方便地处理 HTML(标准通用标记语言下的一个应用)、events、实现动画效果,并且方便地为网站提供 AJAX 交互。jQuery 还有一个比较大的优势是,它的文档说明很全,而且各种应用也说得很详细,同时还有许多成熟的插件可供选择。jQuery 能够使用户的 html 页面保持代码和 html 内容分离,也就是说,不用再在 html 里面插入一堆 js 来调用命令了,只需要定义 id 即可,jQuery 已经成为最流行的 javascript 库,下面给大家推荐几款常用的 JQuery 代码。
1、管理搜索框的值
现在各大网站都有搜索框,而搜索框通常都有默认值,当输入框获取焦点时,默认值消失。而一旦输入框失去焦点,而输入框里又没有输入新的值,输入框里的值又会恢复成默认值,如果往输入框里输入了新值,则输入框的值为新输入的值。这种特效用 JQuery 很容易实现:
$(“#searchbox”)
.focus(function(){$(this).val(”)})
.blur(function(){
var $this = $(this);
// ‘ 请搜索 …’ 为搜索框默认值
($this.val() === ”)? $this.val(‘ 请搜索 …’) : null;
});

2、反序访问 JQuery 对象里的元素
在某些场景下,我们可能需要反序访问通过 JQuery 选择器获取到的页面元素对象,这个怎么实现呢?看下面代码:
// 要掌握 JQuery 对象的 get 方法 以及数组的 reverse 方法即可
var arr = $(‘#nav’).find(‘li’).get().reverse();
$.each(arr,function(index,ele){
…. …
});

3、克隆 table header 到表格的最下面
为了让 table 具有更好的可读性,我们可以将表格的 header 信息克隆一份到表格的底部,这种特效通过 JQuery 就很容易实现:
var $tfoot = $(‘<tfoot></tfoot>’);
$($(‘thead’).clone(true, true).children().get().reverse()).each(function(){
$tfoot.append($(this));
});
$tfoot.insertAfter(‘table thead’);

4、使用 JQuery 重绘图片的大小
关于图片大小的重绘,你可以在服务端来实现,也可以通过 JQuery 在客户端实现。
$(window).bind(“load”, function() {
// IMAGE RESIZE
$(‘#product_cat_list img’).each(function() {
var maxWidth = 120;
var maxHeight = 120;
var ratio = 0;
var width = $(this).width();
var height = $(this).height();

if(width > maxWidth){
ratio = maxWidth / width;
$(this).css(“width”, maxWidth);
$(this).css(“height”, height * ratio);
height = height * ratio;
}
var width = $(this).width();
var height = $(this).height();
if(height > maxHeight){
ratio = maxHeight / height;
$(this).css(“height”, maxHeight);
$(this).css(“width”, width * ratio);
width = width * ratio;
}
});
//$(“#contentpage img”).show();
// IMAGE RESIZE
});

5、滚动时动态加载页面内容
有些网站的网页内容不是一次性加载完毕的,而是在鼠标向下滚动时动态加载的,这是怎么做到的呢?看下面代码:
var loading = false;
$(window).scroll(function(){
if((($(window).scrollTop()+$(window).height())+250)>=$(document).height()){
if(loading == false){
loading = true;
$(‘#loadingbar’).css(“display”,”block”);
$.get(“load.php?start=”+$(‘#loaded_max’).val(), function(loaded){
$(‘body’).append(loaded);
$(‘#loaded_max’).val(parseInt($(‘#loaded_max’).val())+50);
$(‘#loadingbar’).css(“display”,”none”);
loading = false;
});
}
}
});

$(document).ready(function() {
$(‘#loaded_max’).val(50);
});

退出移动版