12 个非常实用的 jQuery 代码片段
来源:互联网 发布:淘宝宝贝图片模板.psd 编辑:程序博客网 时间:2024/06/06 00:56
1.导航菜单背景切换效果
<ul id="nav"> <li>导航1</li> <li>导航1</li> <li>导航1</li> <li>导航1</li></ul>
$('#nav').click(function(e){ $(e.target).addClass('tclass').siblings('tclass').removeClass('tclass');;});2.反序列访问jQuery对象里的元素
在某些场景下,我们可能需要反序访问通过JQuery选择器获取到的页面元素对象。
var items = $('#nav').find('li').get().reverse();$.each(items, function(index, el){ //do something...});3.访问iFrame里的元素
在大多数情况下,IFrame并不是好的解决方案,但由于各种原因,项目中确实用到了IFrame,所以你需要知道怎么去访问IFrame里的元素。
var iFrameDom = $('iframe#id').contents();iFrameDom.find('.message').slideUp();4.管理搜索框的值
$('#searchbox') .focus(function(){$(this).val('');}) .blur(function(){ var $this = $(this); ($this.val() ==='') ? $this.val('请搜索...') : null; })5.部分页面加载更新
为了提高web性能,有更新时我们通常不会加载整个页面,而只是仅仅更新部分页面内容,如图片的延迟加载等。
setInterval(function(){//隔5s加载一次 //获取的内容将增加到 id为content的元素后 $('#content').load(url);}, 5000);6.采用data方法来缓存数据
在项目中,为了避免多次重复的向服务器请求数据,通常会将获取的数据缓存起来以便后续使用。
var cache = {};$.data(cache, 'key', 'value'); //缓存数据//获取数据$.data(cache, 'key');7.jQuery与其他库的兼容
如果在项目中使用JQuery,$ 是最常用的变量名,但JQuery并不是唯一一个使用$作为变量名的库,为了避免命名冲突,你可以按照下面方式来组织你的代码。
//方法1:为jQuery重命名var $jq = jQuery.noConflict();$jq('#id')...//方法2:推荐使用的方式(function($){ //do something....})(jQuery);8.克隆table header到表格的最下面
为了让table具有更好的可读性,我们可以将表格的header信息克隆一份到表格的底部.
var $tfoot = $('<tfoot></tfoot>'); $($('thead').clone(true, true).children().get().reverse()).each(function(){ $tfoot.append($(this));});$tfoot.insertAfter('table thead');9.根据视窗(viewport)创建一个全屏宽度和高度(width/height)的div
根据viewport创建一个全屏的div,这对在不同窗口大小下展示modal或对话框时非常有效.
$('#content').css({ 'width': $(window).width(), 'height': $(window).height()});$(window).resize(function(){ var $win = $(window); $('#content').css({ 'width': $win.width(), 'height': $win.height() });});10.测试密码的强度
某些网站注册时常常会要求设置密码,网站也会根据输入密码的字符特点给出相应的提示,如密码过短、强度差、强度中等、强度强等。
html:
<input type="password" name="pass" id="pass" /> <span id="passstrength"></span>jQuery:
//下面的正则表达式建议各位收藏哦,项目上有可能会用得着$('#pass').keyup(function(e) { //密码为八位及以上并且字母数字特殊字符三项都包括 var strongRegex = new RegExp("^(?=.{8,})(?=.*[A-Z])(?=.*[a-z])(?=.*[0-9])(?=.*\\W).*$", "g"); //密码为七位及以上并且字母、数字、特殊字符三项中有两项,强度是中等 var mediumRegex = new RegExp("^(?=.{7,})(((?=.*[A-Z])(?=.*[a-z]))|((?=.*[A-Z])(?=.*[0-9]))|((?=.*[a-z])(?=.*[0-9]))).*$", "g"); var enoughRegex = new RegExp("(?=.{6,}).*", "g"); if (false == enoughRegex.test($(this).val())) { $('#passstrength').html('More Characters'); } else if (strongRegex.test($(this).val())) { $('#passstrength').className = 'ok'; $('#passstrength').html('Strong!'); } else if (mediumRegex.test($(this).val())) { $('#passstrength').className = 'alert'; $('#passstrength').html('Medium!'); } else { $('#passstrength').className = 'error'; $('#passstrength').html('Weak!'); } return true;});11.使用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});12.滚动时动态加载页面内容
有些网站的网页内容不是一次性加载完毕的,而是在鼠标向下滚动时动态加载的.
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);});
0 0
- jQuery:12 个非常实用的 jQuery 代码片段
- 12 个非常实用的 jQuery 代码片段
- 12 个非常实用的 jQuery 代码片段
- 12 个非常实用的 jQuery 代码片段
- 12 个非常实用的 jQuery 代码片段
- 12 个非常实用的 jQuery 代码片段
- 12 个非常实用的 jQuery 代码片段
- 12 个非常实用的 jQuery 代码片段
- 12 个非常实用的 jQuery 代码片段
- 12 个非常实用的 jQuery 代码片段
- 12 个非常实用的 jQuery 代码片段
- 12 个非常实用的 jQuery 代码片段
- 15 个实用的Jquery代码片段
- 10 个实用的jQuery 代码片段
- 15段非常实用的jQuery代码片段
- (转载)推荐几个非常实用的JQuery代码片段
- 推荐10个非常实用的PHP代码片段
- 10个非常实用的PHP代码片段推荐
- C语言入门----输入语句
- 水管总阀门开关诀窍
- 26 Reciprocal cycles - Project Euler
- 离散傅里叶变换
- oracle存储过程语法
- 12 个非常实用的 jQuery 代码片段
- java.util.ResourceBundle使用详解
- JSR 303 - Bean Validation 介绍及最佳实践
- android--(百度地图)
- Android:开源框架xutils介绍之 DbUtils
- 昂贵的聘礼(dij)
- Android面试题汇总
- 多次请求后tomcat网页假死
- 02 bootstrap "modal : is not a function"