15个常用的jquery代码片段


Posted in Javascript onDecember 19, 2015

本文为大家分享了15个常用的jquery代码片段,分享给大家供大家参考,具体内容如下

1、回到顶部按钮
通过使用 jQuery 中的 animate 和 scrollTop 方法,你无需插件便可创建一个简单地回到顶部动画:

// Back to top
 $('a.top').click(function (e) {
 e.preventDefault();
 $(document.body).animate({scrollTop: 0}, 800);
 });
<!-- Create an anchor tag -->
 <a class="top" href="#">Back to top</a>

将 scrollTop 的值改为你想要 scrollbar 停止的地方。然后你要做的就是,设置在 800 毫秒内回到顶部。

2、预加载图片
如果你的页面使用了大量不能初始可见的图片(例如绑定在 hover 上),预加载它们是十分有用的:

$.preloadImages = function () {
 for (var i = 0; i < arguments.length; i++) {
  $('<img>').attr('src', arguments[i]);
 }
 };
 
 $.preloadImages('img/hover-on.png', 'img/hover-off.png');

3、检查图片是否加载完毕
有时你或许要检查图片是否完全加载完毕,才能在脚本中进行后续操作:

$('img').load(function () {
 console.log('image load successful');
 });

你也可以通过把 img 标签替换成 ID 或 class,来检查特定图片是否加载完成。

4、动修复损坏的图片
如果你发现自己网站的图片链接挂了,一个一个替换很麻烦。这段简单的代码可以帮上大忙:

$('img').on('error', function () {
 $(this).prop('src', 'img/broken.png');
 });

即使你没有任何损坏的链接,增加这段代码也不会有什么影响。

5、Hover 上的 Class 切换
如果用户的鼠标悬停在页面上某个可点击元素时,你想要改变这个元素的视觉表现。可以使用下面这段代码,当用户悬停时,为该元素增加一个 class;当用户鼠标离开后移除这个 class:

$('.btn').hover(function () {
 $(this).addClass('hover');
 }, function () {
 $(this).removeClass('hover');
 });

你仅需增加必须的 CSS。如果需要更简单的方式,还可以使用 toggleClass 方法:

$('.btn').hover(function () {
 $(this).toggleClass('hover');
 });

注意:CSS 或许是这个例子更快速的解决方式,但大家仍然值得知道这一点。

6、禁用 input 字段
有时你也许想让表单的提交按钮或其文本输入框变得不可用,直到用户执行了一个特定行为(例如确认 “我已经阅读该条款” 的复选框)。增加 disabled attribute 到你的 input,就可以实现自己想要的效果:

$('input[type="submit"]').prop('disabled', true);

当你想把 disabled 的值改为 false 时,仅需在该 input 上再运行一次 prop 方法。
$('input[type="submit"]').prop('disabled', false);

7、停止链接加载
有时你不想链接跳转到某个页面或重加载该页面,而希望可以做一些其他事情,比如触发其他脚本。下面的代码是禁止默认行为的一个小诀窍:
$('a.no-link').click(function (e) {
 e.preventDefault();
 });

8、淡入淡出/滑动开关
淡入淡出与滑动是我们经常使用 jQuery 做成的动画效果。或许你只是想在用户点击某物时展现一个元素,使用 fadeIn 和 slideDown 都很棒。但如果想让该元素在第一次点击时显现,第二次点击时消失,下面的代码可以很好地完成这个工作:

// Fade
 $('.btn').click(function () {
 $('.element').fadeToggle('slow');
 });
 
 // Toggle
 $('.btn').click(function () {
 $('.element').slideToggle('slow');
 });

9、简单的手风琴效果
这是一个快速实现手风琴效果的简单方法:

// Close all panels
 $('#accordion').find('.content').hide();
 
 // Accordion
 $('#accordion').find('.accordion-header').click(function () {
 var next = $(this).next();
 next.slideToggle('fast');
 $('.content').not(next).slideUp('fast');
 return false;
 });

增加这段脚本后,你所需做的所有事就是,查看脚本是否在必须的 HTML 中正常工作。

10、使两个 Div 高度一样
有时你也许想让两个 div 拥有同样高度,不管它们里面有什么内容:

('.div').css('min-height', $('.main-div').height());

该例设置了 min-height,意味着它可以比主要 div 更大,但永远不能更小。但有一个更加灵活的方法是遍历一组元素的设置,然后将高度设为元素中的最高值:
var $columns = $('.column');
 var height = 0;
 $columns.each(function () {
 if ($(this).height() > height) {
  height = $(this).height();
 }
 });
 $columns.height(height);

如果你想让所有列都有相同高度:

var $rows = $('.same-height-columns');
 $rows.each(function () {
 $(this).find('.column').height($(this).height());
 });

11、在新标签/窗口打开站外链接
在一个新标签或者新窗口中打开外置链接,并确保站内链接会在相同的标签或窗口中打开:

$('a[href^="http"]').attr('target', '_blank');
$('a[href^="//"]').attr('target', '_blank');
$('a[href^="' + window.location.origin + '"]').attr('target', '_self');

注意:window.location.origin 在 IE 10 中不可用,该 issue 的修复方法。

12、通过文本找到元素
通过使用 jQuery 中的 contains() 选择器,你可以找到某个元素中的文本。如果文本不存在,该元素将会隐藏:

var search = $('#search').val();
 $('div:not(:contains("' + search + '"))').hide();

13、视觉改变触发
当用户焦点在另外一个标签上,或重新回到标签时,触发 JavaScript:

$(document).on('visibilitychange', function (e) {
 if (e.target.visibilityState === "visible") {
  console.log('Tab is now in view!');
 } else if (e.target.visibilityState === "hidden") {
  console.log('Tab is now hidden!');
 }
 });

14、Ajax 调用的错误处理
当某次 Ajax 调用返回 404 或 500 错误,就会执行错误处理。但如果没有定义该处理,其他 jQuery 代码或许会停止工作。可以通过下面这段代码定义一个全局 Ajax 错误处理:

$(document).ajaxError(function (e, xhr, settings, error) {
 console.log(error);
 });

15、插件链式调用
jQuery 支持链式调用插件,以减缓反复查询 DOM,并创建多个 jQuery 对象。看下面示例代码:

$('#elem').show();
 $('#elem').html('bla');
 $('#elem').otherStuff();

上面这段代码,可以通过链式操作大大改进:

$('#elem')
 .show()
 .html('bla')
 .otherStuff();

还有另外一种方法,把元素缓存在变量中(前缀是  $ ):

var $elem = $('#elem');
 $elem.hide();
 $elem.html('bla');
 $elem.otherStuff();

jQuery 中的链式操作和缓存方法,都极大精简和提速了代码。
以上就是本文的全部内容,希望对大家的学习有所帮助。 

Javascript 相关文章推荐
前端开发部分总结[兼容性、DOM操作、跨域等](持续更新)
Mar 04 Javascript
SWFObject 2.1以上版本语法介绍
Jul 10 Javascript
Jquery实现搜索框提示功能示例代码
Aug 13 Javascript
jQuery动态添加、删除元素的方法
Jan 09 Javascript
让JavaScript的Alert弹出框失效的方法禁止弹出警告框
Sep 03 Javascript
js焦点文字滚动效果代码分享
Aug 25 Javascript
Jquery和JS获取ul中li标签的实现方法
Jun 02 Javascript
Ajax高级笔记 JavaScript高级程序设计笔记
Jun 22 Javascript
View.post() 不靠谱的地方你知道多少
Aug 29 Javascript
微信小程序获取用户信息的两种方法wx.getUserInfo与open-data实例分析
May 03 Javascript
详解在Vue.js编写更好的v-for循环的6种技巧
Apr 14 Javascript
Echarts如何重新渲染实例详解
May 30 Javascript
js实现滚动条滚动到页面底部继续加载
Dec 19 #Javascript
jQuery对html元素的取值与赋值实例详解
Dec 18 #Javascript
jQuery打字效果实现方法(附demo源码下载)
Dec 18 #Javascript
jQuery中trigger()与bind()用法分析
Dec 18 #Javascript
jQuery+JSON实现AJAX二级联动实例分析
Dec 18 #Javascript
js获取url传值的方法
Dec 18 #Javascript
JavaScript setTimeout使用闭包功能实现定时打印数值
Dec 18 #Javascript
You might like
CodeIgniter生成静态页的方法
2016/05/17 PHP
PHP将页面中点击数量高的链接进行高亮显示的方法
2016/05/30 PHP
jquery 单击li防止重复加载的实现代码
2010/12/24 Javascript
jquery实现上下左右滑动的方法
2015/02/09 Javascript
javascript使用shift+click实现选择和反选checkbox的方法
2015/05/04 Javascript
jQuery根据元素值删除数组元素的方法
2015/06/24 Javascript
JavaScript实现跨浏览器的添加及删除事件绑定函数实例
2015/08/04 Javascript
玩转JavaScript OOP - 类的实现详解
2016/06/08 Javascript
用vue的双向绑定简单实现一个todo-list的示例代码
2017/08/03 Javascript
元素全屏的设置与监听实例
2017/11/28 Javascript
vue2.0 如何把子组件的数据传给父组件(推荐)
2018/01/15 Javascript
详解如何使用nvm管理Node.js多版本
2019/05/06 Javascript
Vue 中 filter 与 computed 的区别与用法解析
2019/11/21 Javascript
vue-resource post数据时碰到Django csrf问题的解决
2020/03/13 Javascript
vue项目中自定义video视频控制条的实现代码
2020/04/26 Javascript
vue实现输入框自动跳转功能
2020/05/20 Javascript
python网络编程之UDP通信实例(含服务器端、客户端、UDP广播例子)
2014/04/25 Python
Python中方法链的使用方法
2016/02/23 Python
python的paramiko模块实现远程控制和传输示例
2017/10/13 Python
Python两台电脑实现TCP通信的方法示例
2019/05/06 Python
python 读取修改pcap包的例子
2019/07/23 Python
使用pandas读取文件的实现
2019/07/31 Python
Python3.7在anaconda里面使用IDLE编译器的步骤详解
2020/04/29 Python
完美解决python针对hdfs上传和下载的问题
2020/06/05 Python
利用python中的matplotlib打印混淆矩阵实例
2020/06/16 Python
Python内置函数property()如何使用
2020/09/01 Python
CSS3 实用技巧:实现黑白图像效果示例代码
2013/07/11 HTML / CSS
五分钟学会HTML5的WebSocket协议
2019/11/22 HTML / CSS
Lookfantastic德国官网:英国知名美妆购物网站
2017/06/11 全球购物
Hotels.com越南:酒店预订
2019/10/29 全球购物
投标保密承诺书
2014/05/19 职场文书
关爱老人标语
2014/06/21 职场文书
党员反对四风问题思想汇报
2014/09/12 职场文书
离婚协议书范文2014(夫妻感情破裂)
2014/12/14 职场文书
导游词之天津盘山
2019/11/01 职场文书
把77A收信机改造成收音机
2022/04/05 无线电