近期比較烦,对于一个前端白痴来讲,工做方向忽然转向前端这块着实让人蛋疼无比。前段时间简单的学习了下EasyUI,算是对其有一个简单的认知了吧。EasyUI的研究过程当中发现,假设没有掌握JS、JQuery想要进行兴许的开发会很困难。得,又得学下JQuery,一种蛋蛋的忧伤。一直以为前端的水很的深这段时间算是见识到了,哎,只是工做还的继续,吐槽完了,卯足干劲充电吧! javascript
某前端白痴一个,会点html+css+js.JQuery的学习书籍看的是《瑞丽的JQuery》,先入门看了两章,感受能看懂,还不错。css
往后的学习也就打算採用该书了。固然參考网络上的一些博客文章(独立博客)也是十分必须的。 html
认识JQuery以前,有必要了解下javascript。 前端
一种脚本语言,使得网页和用户之间实现了一种实时的、动态的和交互的关系,网页中包括了不少其它的交互性的元素。java
其强大之处不用我这菜鸟再作赘述。只是其自己存在的一些弊端也就形成了兴许js库的产生。基本的三大弊端: jquery
基于javascript上述的缺点,为了简化js的开发一些javascript库诞生了。css3
js库封装了很是多提早定义的对象和有用函数.能更加高速、便捷的创建页面交互元素。ajax
这里对于有哪些js库就再也不多谈了,重点了解下JQuery,这也是本身兴许学习的重点。 编程
一个很优秀的javascript库,对于js性能的理解也是十分的到位的。浏览器
现如今在javasript渐渐隐去时(表喷我),JQuery也愈加的受欢迎了。
JQuery凭借简洁的语法和跨平台的兼容性,极大地简化了js开发人员遍历HTML文档、操做DOM、处理事件、运行动画和开发Ajax的操做。其独特而又优雅的代码风格改变了javascript开发人员设计思路和编敲代码的方式。
JQuery的主旨就是"wirte less do more",写更少的代码,实现不少其它的功能。
无论你是网页设计师、后台开发人员、业余爱好者仍是项目管理者,也不论是javascript刚開始学习的人仍是javascript高手,都有足够的理由去学习JQuery。
jq强调的理念就是"wirte less,do more"。jq独特的选择器、链式的DOM操做、事件处理机制和封装无缺的Ajax都是其它js库所不能达到的。
归纳来讲jq的优点大体分为例如如下几个方面:
(1) 轻量级
jquery是很轻巧的,採用Dean Edwards编写的Packer(http://dean.edwards.name/packer/)压缩后,大小不到30kb。假设使用Min版本号并且在server端启用Gzip压缩后,大小仅仅有18kb。
(2) 强大的选择器
jqery赞成开发人员使用从css1到css3差点儿所有的选择器,以及jquery首创的高级而且复杂的选择器。
(3) 出色的DOM操做的封装
jquery封装了大量常用的DOM操做,使开发人员在编写DOM操做相关程序时候能够驾轻就熟。
jquery轻松的完毕各类本来很复杂的操做,使得js菜鸟也能写出出色的程序。
(4) 可靠的事件处理机制
jquery的事件处理机制吸取了javascript专家Dean Edwards编写的事件处理函数的精华,使得jquery在处理事件绑定的时候至关可靠。
在预留退路、按部就班以及非入侵编程思想方面,jquery也作的很不错。
(5) 无缺的Ajax
jquery将所有的Ajax操做封装到一个函数$.ajax()里,使得开发人员处理ajax的时候能够专心的处理业务逻辑而无需关心浏览器兼容性和XMLHttpRequest对象的建立和使用的问题。
(6) 不污染顶级变量
jquery仅仅是创建了一个名为jquery的对象,器所有的函数都是在这个对象之下的。
其别名也可以随时交出控制权,不会污染其它变量,这使得jquery可以与js和其它js库共存,在项目中放心的引用而不需要考虑到后期可能的冲突。
(7) 出色的兼容性
做为一个流行的js库,jquery的浏览器兼容性也是十分良好的。
(8) 链式操做
对发生在同一个jq对象上的一组动做,可以直接连写而无需反复获取对象。这样的链式操做方式使得jq的代码无比优雅。
而且无需反复获取对象使得性能获得提高(选择器获取对象是比較消耗性能的)。
(9) 隐式迭代
当用jq找到带有".class"类的全部元素,隐藏它们时,无需编写循环遍历每一个返回的元素。jq里面的方法都是被设计成本身主动操做对象的集合,而不是单独的对象,这使得大量的玄幻结构变得再也不必要,优化了代码量。
(10) 行为层与结构层的分离
开发者可以使用jqery选择器获得元素,而后直接给元素加入事件。这样的将行为层与结构层全然分离的思想,使得jquery开发者页面开发者各司其职,避免了一些没必要要的冲突,同一时候也便于后期的维护,不需要再html代码中寻找某些寒素和反复改动html代码。
(11) 丰富的插件支持
jquery是easy扩展的,这使得基于jquery的开源插件愈来愈懂,也愈来愈好,借助于一些开源的插件,能够高速的构建交互性较强的应用。
(12) 开源。
jquery是一个开源的产品,不论什么人都可以自由的使用并提出改进意见。开源使得一个产品更加具备活力,也会促进一个产品的不断改进,同一时候一些新的灵感和idea也将促进产品的深化。
有理由相信开源的JQuery会愈来愈受欢迎。
简单的了解了下jquery接下来简单的尝试下jquery吧。
一、获取jquery
进入jquery官网: http://jquery.com/,下载最新的jquery库。
二、jquery库类型说明
在正式的编写代码以后,有必要了解下jquery库的两种类型:JQuery xxx.min.js(Minified and Gzipped) 和 JQuery xxx.js(Uncompressed)
前者是通过JSMin等工具进行压缩后的版本号,大小为54kb,假设server开启Gzip压缩以后,大小将进一步减少为18kb。主要用户产品和项目。
后者是完整无压缩版本号,主要用户測试、学习和开发。
三、JQuery环境配置
jquery无需安装,仅仅需解压到相关目录中,开发的时候在html页面中引入该.js文件就能够。
一个简单的样例:点击某个div实现隐藏该div,和原生js进行比較,代码例如如下:
<html> <title>JQuery学习入门</title> <script src="js/jquery-1.9.1.js"></script> <head> <style> .div { background: #58c3d6; text-decoration-line: none; text-align: center; line-height: 60px; color: #ffffff; height: auto; } </style> <script> /**经过JQuery库来实现隐藏DIV*/ $(document).ready(function() { $("#div").click(function() { $(this).hide(); }); }); /*经过原生js实现DIV的隐藏、显示*/ function toggle(targetId) { var target = document.getElementById(targetId); if (target.style.display == 'block') { target.style.display = "none"; } else { target.style.display = "block"; } } </script> </head> <body> <button onclick="toggle('div')">开关</button> <div class="div" id="div">点我隐藏</div> </body> </html>
简单的了解了JQuery,也算对jquery有了一个认知吧,兴许的就是一些知识点的积累了,OVER!