第一百六十二节,jQuery入门介绍
jQuery入门
学习要点:
1.什么是 jQuery
2.学习 jQuery的条件
3.jQuery的版本
4.jQuery的功能和优势
5.其他 JavaScript库
6.是否兼容低版本 IE
7.下载及运行 jQuery
一.什么是 jQuery
jQuery是一个JavaScript库,它通过封装原生的JavaScript函数得到一整套定义好的方
法。它的作者是John Resig,于2006年创建的一个开源项目,随着越来越多开发者的加入,
jQuery已经集成了JavaScript、CSS、DOM和Ajax于一体的强大功能。它可以用最少的代码,
完成更多复杂而困难的功能,从而得到了开发者的青睐。
二.学习jQuery的条件
jQuery是JavaScript库,所以jQuery在使用上要比原生的JavaScript要简单,但是对于
网页编程来说,有些通用的基础知识是必备的:
1.XHTML或HTML5(含CSS,网页必备的基础技术,XHTML已完结90课);
2.JavaScript(虽然jQuery使用比JavaScript简单,但各种语法来自JavaScript,只要掌
握已出课程的第一季149课即可,并不需要完全精通,只要理解语法和项目中简单的用法即
可。);
3.服务器语言如:PHP(jQuery属于前端技术,那和后端技术是相辅相成、互相呼应的,
而PHP课程目前出到第四季,而jQuery只需要PHP第一季136课的基础即可。);
三.jQuery的版本
从 2005年 8月开始,进入公共开发阶段,随之而来的新框架于 2006年 1月 14日正
式以 jQuery的名称发布。
2006年 8月发布了 jQuery1.0,第一个稳定版本,具有对 CSS选择符、事件处理和
Ajax交互的支持。
2007年 1月发布了 jQuery1.1,极大的简化 API。合并了许多较少使用的方法。
2007年 7月发布了 jQuery1.1.3,优化了 jQuery选择符引擎执行的速度。
2007年 9月发布了 jQuery1.2,去掉了 XPath选择器,新增了命名空间事件。
2008年 5月发布了 jQuery1.2.6,引入了 Dimensions插件到核心库中。
2009年 1月发布了 jQuery1.3,使用了全新的选择符引擎 Sizzle,性能进一步提升。
2010年 1月发布了 jQuery1.4,进行了一次大规模更新,提供了 DOM操作,增加了很
多新的方法或是增强了原有的方法。
2010年 2月发布了 jQuery1.4.2,添加了.delegate()和.undelegate()两个新方法,提升
了灵活性和浏览器一致性,对事件系统进行了升级。
2011年 1月发布了 jQuery1.5,重写了 AJAX组件,增强了扩展性和性能。
2011年 5月发布了 jQuery1.6,重写了 Attribute组件,引入了新对象和方法。
2011年 11月发布了 jQuery1.7,引入了.on()和.off()简介的 API解决事件绑定及委托容
易混淆的问题。
2012年 3月发布了 jQuery1.7.2,进行一些优化和升级。
2012年 7月发布了 jQuery1.8,8月发布了 1.8.1,9月发布了 1.8.2,重写了选择符引
擎,修复了一些问题。
2013年 1月发布了 jQuery1.9,CSS的多属性设置,增强了 CSS3。
2013年 5月发布了 jQuery1.10,增加了一些功能。
2013年 4月发布了 jQuery2.0,5月发布了 jQuery2.0.2,一个重大更新版本,不在支
持 IE6/7/8,体积更小,速度更快。
在制作这套课程的时候,我们最新的中文版的 API文档是 1.8版本的,有在线和离线两
种手段查阅:
1.在线的可以访问:http://t.mb5u.com/jquery/
2.离线的 AP文档将打包提供给大家
3.如果要看最新的文档,英文版的:http://api.jquery.com/看不懂可以打开谷歌翻译,虽
然不是特别准。
关于版本学习的问题:
版本的版本号升级主要有三种:第一种是大版本升级,比如 1.x.x升级到 2.x.x,这种升
级规模是最大的,改动的地方是最多的,周期也是最长的,jQuery从 1.x.x到 2.x.x用了 7
年。第二种是小版本更新,比如 1.7升级到 1.8,改动适中,增加或减少了一些功能,一般
周期半年到一年左右。第三种是微版本更新,比如 1.8.1升级到 1.8.2,修复一些 bug或错误
之类。
版本的内容升级主要也有三种:第一种是核心库的升级,比如优化选择符、优化 DOM
或者 AJAX等;这种升级不影响开发者的使用。第二种是功能性的升级,比如剔除一些过
时的方法、新增或增强一些方法等等;这种升级需要了解和学习。第三种就是 BUG修复之
类的升级,对开发者使用没有影响。
学习者有一种担忧,比如学了 1.3版本的 jQuery,那么以后升级新版本是不是还需要重
学?没必要,因为并不是每次升级一个版本都会增加或剔除功能的,一半左右都是内部优化,
升级到新版本并不需要任何学习成本。就算在新的版本增加了一些功能,只需要几分钟了解
一下即可使用,无需清零之前的知识,只需后续累加。当然,在早期的 jQuery版本都创建
了最常用的功能,而新版本中增加的功能,也不是最常用的,无需立即学习,立马用起。
四.jQuery的功能和优势
jQuery作为 JavaScript封装的库,他的目的就是为了简化开发者使用 JavaScript。主要
功能有以下几点:
1.像 CSS那样访问和操作 DOM
2.修改 CSS控制页面外观
3.简化 JavaScript代码操作
4.事件处理更加容易
5.各种动画效果使用方便
6.让 Ajax技术更加完美
7.基于 jQuery大量插件
8.自行扩展功能插件
jQuery最大的优势,就是特别的方便。比如模仿 CSS获取 DOM,比原生的 JavaScript
要方便太多。并且在多个 CSS设置上的集中处理非常舒服,而最常用的 CSS功能又封装到
单独的方法,感觉非常有心。最重要的是 jQuery的代码兼容性非常好,你不需要总是头疼
着考虑不同浏览器的兼容问题。
五.其他 JavaScript库
目前除了 jQuery,还有 5个库较为流行,他们分别是 YUI、Prototype、Mootools、Dojo
和 ExtJS。
YUI,是雅虎公司开发的一套完备的、扩展性良好的富交互网页工具集。
Prototype,是最早成型的 JavaScript库之一,对 JavaScript内置对象做了大量的扩展。
Dojo,Dojo强大之处在于提供了其他库没有的功能。离线存储、图标组件等等。
Mootools,轻量、简洁、模块化和面向对象的 JavaScript框架。
ExtJS,简称 Ext,原本是对 YUI的一个扩展,主要创建前端用户界面。(付费的)
六.是否兼容 IE低版本
这次 jQuery发布了大版本 2.x.x,完全放弃兼容 IE6/7/8。不单单如此,很多国际上的大
型站点也开始逐步不再支持 IE6/7/8。但对于国内而言,比较大型的网站最多只是抛弃 IE6,
或者部分功能不支持 IE6的警示框,还没可能一下子把 IE6/7/8全面抛弃。这里我们就谈一
谈你的项目是否有必要兼容 IE6/7/8。
完全不支持 IE6的示例:网易云课堂 -- http://study.163.com
部分功能不支持 IE6的示例:Q+ -- http://web.qq.com
完全不支持的做法,就是检测到是否为 IE6或者 IE6/7/8,然后直接跳转到一个信息错
误界面,让你更换或升级浏览器,否则无法访问使用。
部分功能不支持的做法,就是判断你是 IE6或 IE6/7/8,然后给一个警示条或弹窗,告
诉你使用此款浏览器性能降低或部分功能使用不正常或不能使用的提示,但还可以访问使
用。
虽然大部分国内网站用 IE6去运行都能基本兼容,但很多细节上还是有些问题,导致不
能流畅的去使用。
疑问:我们新做的项目应不应该再兼容 IE6或 IE6/7/8?
这个问题争论很久,支持兼容的人会拿国情和使用率来证明。不支持兼容的人会用技术
落后导致整个落后别国来证明。其实这两种都有商榷的地方。
首先,传统行业失败率为 97%,而新新的 IT行业更高达 99%以上(数据可能不精确,
但可以说明失败率很高)。那么站在更高的角度去看你的项目,你不管是付出 3倍成本去完
成一个用户体验一般,但兼容性很好的项目;还是付出正常成本去完成用户体验很好,但不
兼容低版本浏览器;这两种情况不管是哪一种,最终可能都会失败。那么你愿意选择哪种?
是否兼容 IE6或 IE6/7/8并不单纯是用户基数和国情的问题,而很多项目发起人只一味
的用这种理由去判定需求,那么失败也在所难免。除了这个方面,我们还应该考虑更多的方
面:
1.成本控制
很多项目往往在 6、12、18、32...个月就会发生财务问题,比如资金紧缩甚至断裂。所
以,成本控制尤为重要。项目如果不是老站升级,也不是大门户的新闻站,成本控制和尽快
上线测试才是最重要的。而如果新站一味要求全面兼容,会导致成本加剧(随着功能多少,
成本倍率增加)。为了锁紧时间,就不停的加班再加班,又导致员工抵触,工作效率降低,
人员流动开始频繁,新员工又要接手开发一半的项目。这样成本不停的再累加。最终不少项
目,根本没上线就失败了。
2.用户选择
用户一般可以分为两种用户:高质量用户和低质量用户。所谓高质量用户,就是为了一
款最新的 3D游戏去升级一块发烧级的显卡,或直接换一台整机。所谓低质量用户,发现不
能玩最新的 3D游戏,就放弃了,去玩“植物大战僵尸”解解馋算了。在用户选择上有一个
很好的案例,就是移动互联网。网易和腾讯在他们的新闻应用上,他们兼容了几乎所有的手
机平台,比如 IOS、安卓、黑莓、塞班等等,因为新闻应用的核心在新闻,而新闻的用户基
数巨大,需要兼顾高质量和低质量用户。而腾讯在 IOS上的几十个应用,除了新闻、QQ、
浏览器,其他的基本都只有 IOS和安卓,在塞班和黑莓及其他上就没有了。
所以,你的应用核心是哪方面?兼容的成本有多大?会不会导致成本控制问题?用户选
择尤为重要,放弃低质量用户也是一种成本控制。在用户基数庞大的项目上,放弃低质量用
户就有点愚笨,比如某个新闻站有 1亿用户,2000万为使用低版本浏览器的低质量的用户,
而面对 2000万用户,你兼容它或单独为 2000万做个低版本服务,成本虽然可能还是 3倍,
但对于庞大的用户基数来看,这种成本又非常低廉。而你的用户基数只有 1000人,而低质
量用户有 50人,那么为了这 50人去做兼容,那么 3倍的成本就变得非常的昂贵。
3.项目侧重点
你的项目重点在哪里?是为了看新闻?是为了宣传线下产品?那么你其实有必要兼容
低版本浏览器。首先这种类型的站不需要太好的用户体验,不需要太多的交互操作,只是看,
而兼容的成本比较低,并且核心在新闻或产品!但如果你的项目有大量的交互、大量的操作,
比如全球最大的社交网已经不兼容 IE6/7,最大的微博也不再兼容 IE6/7,就是这个原因。所
以,项目并不是一味的全面兼容,或者全面不兼容,主要看你的项目侧重点在哪里!
4.用户体验
如果你的项目在兼容低版本浏览器成本巨大,比如社交网,有大量的 JS和 AJAX操作。
那么兼容 IE6/7的成本确实很高,如果兼容,用户体验就会很差。兼容有两种,一种是高版
本浏览器用性能好,体验好的模式;低版本的自动切换到兼容模式。第二种就是,不管高版
本或低版本都用统一的兼容模式。这两种成本都很高。用户体验好的模式,能增加用户粘度,
增加付费潜在用户,而用户体验差的总是被用户归纳为心目中的备胎(所谓备胎就是实在没
有了才去访问,如果有,很容易被抛弃)。
5.数据支持
如果对某一种类型的网站项目有一定的研究,那么手头必须有支持的数据分析。有数据
分析可以更好的进行成本控制,更有魄力的解决高低质量用户的取舍。
瓢城 Web俱乐部浏览器比例图
6.教育用户
很多项目可能是有固定客户群,或者使用该项目人员质量普遍较高。那么,面对零星一
点的低质量用户,我们不能再去迎合他。因为迎合他,就无法用高质量的用户体验去粘住忠
实用户,又不能获取到低质量用户的芳心。所以,我们应有的策略是:牢牢把握住高质量的
忠诚用户,做到他们心目中的第一;教育那部分低质量用户(比如企业级开发项目,可以直
接做企业培训,安装高版本浏览器等等。互联网项目,就给出提示安装高版本浏览器即可)。
那么一部分低质量用户被拉拢过来,还有一小撮死性不改的就只有放弃。切不可捡了芝麻丢
了西瓜,不要贪大求全。
PS:我们用了这六点讨论了一下是否需要兼容 IE6或 IE6/7/8,结论就是必须根据实际
情况,你项目的成本情况、人员情况、用户情况和项目本身类型情况而制定,没有一刀切的
兼容或不兼容。
七.下载及运行 jQuery
目前最新的版本,是 1.10.1和 2.0.2,我们下载开发版,可以顺便读一读源代码。如果
你需要引用到你线上的项目,就必须使用压缩版,去掉了注释和空白,是容量最小。
本课程使用的软件是:Nodepad++
使用测试的浏览器为:Firefox3.6.8、Firefox21+、Chrome、IE6/7/8/9、Opera和 Safari
使用的版本为:1.10.1、2.02作为抛弃 IE6/7/8版本会在单独章节中讲解
使用的 html版本为:xhtml1.0,在必要的时候将会使用 html5
使用的调试工具:Firefox下的 firebug
//单击按钮弹窗
$(function () {
$('input').click(function () {
alert('第一个 jQuery程序!');
});
});
主讲这两个版本
jquery-1.10.1.js 支持IE6,7,8 (主讲)
jquery-2.0.2.js 不支持IE6,7,8
第一百六十二节,jQuery入门介绍的更多相关文章
- 第三百六十二节,Python分布式爬虫打造搜索引擎Scrapy精讲—elasticsearch(搜索引擎)基本的索引和文档CRUD操作、增、删、改、查
第三百六十二节,Python分布式爬虫打造搜索引擎Scrapy精讲—elasticsearch(搜索引擎)基本的索引和文档CRUD操作.增.删.改.查 elasticsearch(搜索引擎)基本的索引 ...
- 第一百七十二节,jQuery,动画效果
jQuery,动画效果 学习要点: 1.显示.隐藏 2.滑动.卷动 3.淡入.淡出 4.自定义动画 5.列队动画方法 6.动画相关方法 7.动画全局属性 一.显示.隐藏 jQuery 中显示方法为:. ...
- 第一百六十三节,jQuery,基础核心
jQuery,基础核心 一.代码风格 在jQuery程序中,不管是页面元素的选择.内置的功能函数,都是美元符号“$”来起 始的.而这个“$”就是jQuery当中最重要且独有的对象:jQuery对象,所 ...
- 第一百九十二节,jQuery EasyUI 使用
jQuery EasyUI 使用 学习要点: 1.引入必要的文件 2.加载 UI 组件的方式 3.使用 easyload.js 智能加载 4.Parser 解析器 本节课重点了解 EasyUI 的两种 ...
- 第一百六十八节,jQuery,表单选择器
jQuery,表单选择器 学习要点: 1.常规选择器 2.表单选择器 3.表单过滤器 表单作为 HTML 中一种特殊的元素,操作方法较为多样性和特殊性,开发者不但可以 使用之前的常规选择器或过滤器,也 ...
- 第一百六十五节,jQuery,过滤选择器
jQuery,过滤选择器 学习要点: 1.基本过滤器 2.内容过滤器 3.可见性过滤器 4.子元素过滤器 5.其他方法 过滤选择器简称:过滤器.它其实也是一种选择器,而这种选择器类似与 CSS3 (h ...
- 第一百六十四节,jQuery,常规选择器
jQuery,常规选择器 学习要点: 1.简单选择器 2.进阶选择器 3.高级选择器 jQuery 最核心的组成部分就是:选择器引擎.它继承了 CSS 的语法,可以对 DOM 元 素的标签名.属性名. ...
- 第一百六十九节,jQuery,基础事件
jQuery,基础事件 学习要点: 1.绑定事件 2.简写事件 3.复合事件 JavaScript 有一个非常重要的功能,就是事件驱动.当页面完全加载后,用户通过鼠标 或键盘触发页面中绑定事件的元素即 ...
- 第一百六十七节,jQuery,DOM 节点操作,DOM 节点模型操作
jQuery,DOM 节点操作,DOM 节点模型操作 学习要点: 1.创建节点 2.插入节点 3.包裹节点 4.节点操作 DOM 中有一个非常重要的功能,就是节点模型,也就是 DOM 中的“M”.页面 ...
随机推荐
- Node.js abaike图片批量下载爬虫1.02
//====================================================== // abaike图片批量下载爬虫1.02 // 用最近的断点续传框架改写原有1.01 ...
- Mybatis错误:Result Maps collection already contains value for 。。。。
解决方法 原因:xml文件中存在重名对象,保持名称不要一样即可正常启动.因为我再次使用逆向工程生成mapper接口和xml文件时,忘了删除原来的xml文件,新生成的与旧的同时出现旧重复了. 那么我们在 ...
- MongoDB数据库设计中6条重要的经验法则
Part 1 原文:6 Rules of Thumb for MongoDB Schema Design: Part 1 By William Zola, Lead Technical Support ...
- WCF 之 概述
WCF全称是Windows Communication Foundation,它是.NET3.0的重要组成部分,用来解决Windows下的一些通信方面的问题.WCF是Microsoft平台上的SOA架 ...
- .Net Framework 之 托管代码和非托管代码的区别
一.什么是托管代码(managed code)? 托管代码:是微软的中间语言(IL),即微软中间语言MSIL(Microsoft Interspace Language). “ 源代码→机器码 ”运行 ...
- js 因加入form导致两个table之间出现空白问题
在<FORM>中加CSS <table> ....... </table> <form style="padding:0; margin:0;&qu ...
- Cacti监控mysql数据库服务器实现过程
Cacti监控mysql数据库服务器实现过程 2014-05-29 0个评论 来源:Cacti监控mysql数据库服务器实现过程 收藏 我要投稿 1 先在cacti服务器端安 ...
- iOS开发一个制作Live Photo的工具
代码地址如下:http://www.demodashi.com/demo/13339.html 1.livePhoto简介 livePhoto是iOS 9.0 之后系统相机提供的拍摄动态照片的功能,但 ...
- Linux-Nginx-关闭进程
当然就仅仅是介绍一条命令了,就这么简单. nginx默认创建一个工作进程 root 2713 1 0 07:56 ? 00:00:00 nginx: master process ../sbin/ng ...
- 全排列算法 --javascript 实现
var Ann = function a(arr){ if(arr.length == 1){return arr;} var rr = new Array(); for(var i = 0; i&l ...