本文转自:http://developer.51cto.com/art/201604/509093.htm

作者:核子可乐译来源:51CTO

原文标题:10
jQuery Snippets for Efficient Web Development

JQuery是继prototype之后又一个优秀的Javascript库。它是轻量级的js库 。它兼容CSS3,还兼容各种浏览器(IE 6.0+, FF 1.5+, Safari 2.0+, Opera 9.0+),jQuery2.0及兴许版本号将不再支持IE6/7/8浏览器。jQuery使用户能更方便地处理HTML(标准通用标记语言下的一个应用)、events、实现动画效果,并且方便地为站点提供AJAX交互。jQuery另一个比較大的优势是,它的文档说明非常全。并且各种应用也说得非常具体,同一时候还有很多成熟的插件可供选择。jQuery可以使用户的html页面保持代码和html内容分离,也就是说,不用再在html里面插入一堆js来调用命令了,仅仅须要定义id就可以。下面十项jQuery演示样例可以帮助大家的Web设计项目顺利实现效率提升。

1.检測IE浏览器

在进行CSS设计时,IE浏览器对开发人员及设计师而言无疑是个麻烦。虽然IE6的黑暗时代已经过去,IE浏览器家族的人气亦在不断下滑。但我们仍然有必要对其进行检測。当然,下面片段亦可用于检測其他浏览器。

$(document).ready(function() {
if (navigator.userAgent.match(/msie/i) ){
alert('I am an old fashioned Internet Explorer');
}
});

来源: Stack
Overflow

     2.平滑滚动至页面顶部

下面是jQuery最为常见的一种实现效果:点击一条链接以平滑滚动至页面顶部。尽管没什么新奇感可言,但每位开发人员差点儿都用得上。

$("a[href='#top']").click(function() {
$("html, body").animate({ scrollTop: 0 }, "slow");
return false;
});

来源: Stalk
Overflow

     3.保持始终处于顶部

下面代码片段同意某一元素始终处于页面顶部。能够想见,其很适合处理导航菜单、工具栏或者其他重要信息。

$(function(){ 

var $win = $(window) 

var $nav = $('.mytoolbar'); 

var navTop = $('.mytoolbar').length && $('.mytoolbar').offset().top; 

var isFixed=0; 

processScroll() 

$win.on('scroll', processScroll) 

function processScroll() { 

var i, scrollTop = $win.scrollTop() 

if (scrollTop >= navTop && !isFixed) { 

isFixed = 1 

$nav.addClass('subnav-fixed') 

} else if (scrollTop <= navTop && isFixed) { 

isFixed = 0 

 $nav.removeClass('subnav-fixed') 

} 

} 

来源: DesignBump

     4.替换html标签

jQuery可以很轻松地实现html标签替换,而这也将为我们带来很多其它新的可能。

$('li').replaceWith(function(){ 

  return $("<div />").append($(this).contents()); 

}); 

来源: Allure Web Solutions

     5.检測屏幕宽度

如今移动设备的人气差点儿已经超过了传统计算机。因此对小型屏幕的尺寸进行检測就变得很重要。幸运的是,我们能够利用jQuery轻松实现这项功能。

var responsive_viewport = $(window).width(); 

/* if is below 481px */ 

if (responsive_viewport < 481) { 

    alert('Viewport is smaller than 481px.'); 

} /* end smallest screen */ 

来源:jQuery Rain

     6.自己主动修复损坏图片

假设大家的网站很庞大并且已经上线数年,那么当中或多或少会出现图片损坏的情况。这项功能能够检測损坏图片并依据我们的选择加以替换。

$('img').error(function(){ 

$(this).attr('src', 'img/broken.png'); 

}); 

来源:WebDesignerDepot

     7.检測复制、粘贴与剪切操作

利用jQuery。大家能够很轻松地检測到选定元素的复制、粘贴与剪切操作。

$("#textA").bind('copy', function() { 

    $('span').text('copy behaviour detected!') 

}); 

$("#textA").bind('paste', function() { 

    $('span').text('paste behaviour detected!') 

}); 

$("#textA").bind('cut', function() { 

    $('span').text('cut behaviour detected!') 

}); 

来源: Snipplr

    8.自己主动为外部链接加入target=“blank”属性

在链接至外部网站时,大家可能希望使用target="blank"属性以确保在新的选项卡中打开页面。

问题在于。target="blank"属性并未经过W3C认证。

jQuery可以帮上大忙:下面片段可以检測当前链接是否指向外部。假设是则自己主动为其加入target="blank"属性。

var root = location.protocol + '//' + location.host; 

$('a').not(':contains(root)').click(function(){ 

    this.target = "_blank"; 

}); 

来源: jQuery Rain

     9.悬停时淡入/淡出

又是还有一项“经典”效果,大家能够利用下面片段随时加以运用。

$(document).ready(function(){ 

    $(".thumbs img").fadeTo("slow", 0.6); // This sets the opacity of the thumbs to fade down to 60% when the page loads 

    $(".thumbs img").hover(function(){ 

        $(this).fadeTo("slow", 1.0); // This should set the opacity to 100% on hover 

    },function(){ 

        $(this).fadeTo("slow", 0.6); // This should set the opacity back to 60% on mouseout 

    }); 

}); 

来源: Snipplr

      10.禁用文本/password输入中的空格

不管是电子邮件、username还是password。非常多常见字段都不须要使用空格。下面代码可以轻松禁用选定输入内容中的所有空格。

$('input.nospace').keydown(function(e) { 

if (e.keyCode == 32) { 

return false; 

} 

}); 

十条很实用的jQuery代码片段的更多相关文章

  1. 很实用的JQuery代码片段(转)

    1 元素屏幕居中 jQuery.fn.center = function () { this.css("position","absolute"); this. ...

  2. 经验分享:10个简单实用的 jQuery 代码片段

    尽管各种 JavaScirpt 框架和库层出不穷,jQuery 仍然是 Web 前端开发中最常用的工具库.今天,向大家分享我觉得在网站开发中10个简单实用的 jQuery 代码片段. 您可能感兴趣的相 ...

  3. 10个简单实用的 jQuery 代码片段

    尽管各种 JavaScirpt 框架和库层出不穷,jQuery 仍然是 Web 前端开发中最常用的工具库. 今天,向大家分享我觉得在网站开发中10个简单实用的 jQuery 代码片段. 1.平滑滚动到 ...

  4. 一些实用的JQuery代码片段收集

    本文将展示50个非常实用的JQuery代码片段,这些代码能够给你的JavaScript项目提供帮助.其中的一些代码段是从jQuery1.4.2才开始支持的做法,另一些则是真正有用的函数或方法,他们能够 ...

  5. 12 个非常实用的 jQuery 代码片段

    jQuery是一个非常流行而且实用的JavaScript前端框架,本文并不是介绍jQuery的特效动画,而是分享一些平时积累的12个jQuery实用代码片段,希望对你有所帮助. 导航菜单背景切换效果 ...

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

    jQuery是一个兼容多浏览器的javascript库,核心理念是write less,do more(写得更少,做得更多).jQuery使用户能更方便地处理HTML(标准通用标记语言下的一个应用). ...

  7. js动态判断密码强度&&实用的 jQuery 代码片段

    // 网上拷贝的代码,效果不太好需要自己调整<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" &q ...

  8. 一些实用的JQuery代码片段收集(筛选,搜索,样式,清除默认值,多选等)

    //each遍历文本框 清空默认值 $(".maincenterul1").find("input,textarea").each(function () { ...

  9. 很棒的jQuery代码片段分享

    jQuery实现的内链接平滑滚动 不需要使用太复杂的插件,只要使用下载这段代码即可实现基于内部链接的平滑滚动 $('a[href^="#"]').bind('click.smoot ...

随机推荐

  1. asp.net后台发送HTTP请求

    一.文件流方式(转自:http://blog.csdn.net/u011511086/article/details/53216330) /// 发送请求 /// </summary> / ...

  2. mybatis从数据库中取到的date格式不是yyyy-MM-dd HH:mm:ss

    问题:sqlserver中的存储时间格式为date,pojo的时间属性也是date,直接mybatis取出的时间格式是带英语的那种,不满足客户要求. 解决:将pojo的时间属性改为string类型,在 ...

  3. 二:SQL映射文件

    二:SQL映射文件 1.SQL映射文件: (1)mapper:映射文件的根元素节点,只有一个属性namespace(命名空间) 作用:用于区分不同的mapper全局唯一 绑定dao接口即面向接口编程, ...

  4. 聊下 git 多账户问题

    git 多账户问题 标签(空格分隔):git github gitlab git多账户 背景 git 多账号配置 ssh 多密钥对配置 背景 在使用 git 的时候我们都会面临多账户问题,比较常见的就 ...

  5. Zuul(SpringCloud学习笔记一)

    路由是微服务架构中必须(integral )的一部分,比如,"/" 可能映射到你的WEB程序上,"/api/users "可能映射到你的用户服务上," ...

  6. 基于树莓派的智能家居项目的设想与实现 Hestia

    注:本人内容的准确性仅限于笔者写该篇文章时的情况,不保证后续与实际项目代码一致.实时内容还请关注Github项目托管页面:https://github.com/GenialX/hestia-serve ...

  7. Python Base64 编码

    0x00 Base64简介 0x01 常用场景举例 0x02 编.解码流程 0x03 Python中Base64编码与解码 0x00 Base64简介 我们知道在计算机中任何数据都是按ascii码存储 ...

  8. vue-router在ie9及以下history模式支持

    参考: https://www.npmjs.com/package/vue-route https://github.com/devote/HTML5-History-API 提要: ie9及以下不支 ...

  9. 使用numpy实现批量梯度下降的感知机模型

    生成多维高斯分布随机样本 生成多维高斯分布所需要的均值向量和方差矩阵 这里使用numpy中的多变量正太分布随机样本生成函数,按照要求设置均值向量和协方差矩阵.以下设置两个辅助函数,用于指定随机变量维度 ...

  10. 分布式缓存之Ehcache与terracotta - Terracotta服务器概念篇

    1.介绍 Terracotta服务器为Terracotta产品提供分布式数据平台.Terracotta服务器集群被称为Terracotta服务器阵列(TSA).Terracotta服务器阵列可以从单个 ...