JQuery从0到大技术牛人学习之路!

一、JQuery简介


1.1简介

jQuery是继prototype之后又一个优秀的JavaScript库。它是轻量级的js库 ,它兼容CSS3,还兼容各种浏览器(IE 6.0+, FF1.5+, Safari 2.0+, Opera 9.0+),jQuery2.0及后续版本将不再支持IE6/7/8浏览器。jQuery使用户能更方便地处理HTML标准通用标记语言下的一个应用)、events、实现动画效果,并且方便地为网站提供AJAX交互。jQuery还有一个比较大的优势是,它的文档说明很全,而且各种应用也说得很详细,同时还有许多成熟的插件可供选择。jQuery能够使用户的html页面保持代码和html内容分离,也就是说,不用再在html里面插入一堆js来调用命令了,只需要定义id即可。

jQuery是免费、开源的,使用MIT许可协议。jQuery的语法设计可以使开发更加便捷,例如操作文档对象、选择DOM元素、制作动画效果、事件处理、使用Ajax以及其他功能。除此以外,jQuery提供API让开发者编写插件。其模块化的使用方式使开发者可以很轻松的开发出功能强大的静态或动态网页。


1.2优点


(1)写少代码,做多事情【write less do more】
-    (2)免费,开源且轻量级的js库,容量很小
-         注意:项目中,提倡引用min版的js库
-    (3)兼容市面上主流浏览器,例如 IE,Firefox,Chrome
-         注意:jQuery不是将所有JS全部封装,只是有选择的封装
-    (4)能够处理HTML/JSP/XML、CSS、DOM、事件、实现动画效果,也能提供异步AJAX功能
-    (5)文档手册很全,很详细
-    (6)成熟的插件可供选择
-    (7)提倡对主要的html标签提供一个id属性,但不是必须的
-    (8)出错后,有一定的提示信息
-    (9)不用再在html里面通过<script>标签插入一大堆js来调用命令了


二、JQuery的九类选择器


使用jquery,首先我们需要去把jquery的包导入,这个jquery的官网上面是可以下载的,地址:https://jquery.com/,目前最新版本是3.0,一般会有两种版本的,一个是完全的,一个是迷你版本的,两个版本就是大小不一样,里面的实质性东西其实是一样的,而这个迷你版的适合项目正式上线使用,因为占的体积小啊,一般学习或者练习的话就可以尝试使用完全版的。下面以几个案例来实际说明jquery的使用,完整的代码会在文末提供下载链接,欢迎下载学习。选择器的部分在下载的文件中的/JQuery\WebRoot\selector目录下。

2.1 基本选择器

[javascript]  view plain  copy
 print ?
  1. //1)查找ID为"div1ID"的元素个数  
  2.     alert(  $("#div1ID").size());  
  3.       
  4.       
  5.     //2)查找DIV元素的个数  
  6.      alert( $("div").length);  
  7.       
  8.       
  9.     //3)查找所有样式是"myClass"的元素的个数  
  10.     alert($(".myClass").size());  
  11.       
  12.   
  13.     //4)查找所有DIV,SPAN,P元素的个数  
  14.     alert($("div,span,p").size());  
  15.       
  16.   
  17.     //5)查找所有ID为div1ID,CLASS为myClass,P元素的个数  
  18.     alert($("#div1ID,.myClass,p").size());  



2.2 层次选择器

[javascript]  view plain  copy
 print ?
  1. //1)找到表单form里所有的input元素的个数  
  2.     alert($("form input").size());  
  3.       
  4.     //2)找到表单form下所有的子级input元素个数  
  5.     alert($(" form > input").size());  
  6.       
  7.       
  8.     //3)找到表单form同级第一个input元素的value属性值  
  9.     alert($("form + input").val());  
  10.       
  11.       
  12.     //4)找到所有与表单form同级的input元素个数  
  13.     alert($("form ~ input").size());  
  14.       


2.3 增强基本选择器

[javascript]  view plain  copy
 print ?
  1. //1)查找UL中第一个元素li的内容  
  2.     alert($("ul li:first").html());    
  3.     alert($("ul li:first").text());   
  4.     //html()要用在html/jsp中,不能用在xml中,而text()都可以用  
  5.       
  6.       
  7.     //2)查找UL中最后一个元素的内容  
  8.     alert($("ul li:last").text());   
  9.       
  10.       
  11.     //3)查找所有未选中的input元素个数  
  12.     alert($(":checkbox:checked").size());  //选中的    2  
  13.     alert($(":checkbox:not(:checked)").size());  //未选中  
  14.       
  15.       
  16.     //4)查找表格的1、3、5...奇数行个数  
  17.     alert($("table tr:odd").size());  //3  
  18.       
  19.       
  20.     //5)查找表格的2、4、6...偶数行个数  
  21.     alert($("table tr:even").size());  //3  
  22.       
  23.       
  24.     //6)查找表格中第二行的内容,从索引号0开始  
  25.     alert($("table tr:eq(1)").text());  
  26.     //html()强调的是标签中的内容,即便标签中有子标签,也会显示出来,而text()强调的是标签中的文本内容,不会显示子标签  
  27.       
  28.       
  29.     //7)查找表格中第二第三行的个数,即索引值是1和2,也就是比0大  
  30.     alert($("table tr:gt(0)").size());  //5  
  31.       
  32.       
  33.     //8)查找表格中第一第二行的个数,即索引值是0和1,也就是比2小  
  34.     alert($("table tr:lt(3)").size());   
  35.       
  36.       
  37.     //9)给页面内所有标题<h1><h2><h3>加上红色背景色  
  38.     alert($(":header").css("background-color","red").css("color","white"));  
2.4 内容选择器

[javascript]  view plain  copy
 print ?
  1. //1)查找所有包含文本"John"的div元素的个数  
  2.     alert($("div:contains('John')").size());  //2  
  3.       
  4.       
  5.     //2)查找所有p元素为空的元素个数  
  6.     alert($("p:empty").size());  //2  
  7.       
  8.       
  9.     //3)给所有包含p元素的div元素添加一个myClass样式  
  10.     $("div:has(p)").addClass("myClass");  
  11.       
  12.       
  13.     //4)查找所有含有子元素或者文本的p元素个数,即p为父元素  
  14.     alert($("p:parent").size());  //2  

2.5 可见性选择器

[javascript]  view plain  copy
 print ?
  1. //1)查找隐藏的tr元素的个数  
  2.         alert($("table tr:hidden").size());  //1  
  3.           
  4.           
  5.         //2)查找所有可见的tr元素的个数  
  6.         alert($("table tr:not(:hidden)").size());  
  7.         alert($("table tr:visible").size());  //2  

2.6 属性选择器

[java]  view plain  copy
 print ?
  1. //1)查找所有含有id属性的div元素个数  
  2.         alert($("div[id]").size());  //1  
  3.           
  4.           
  5.         //2)查找所有name属性是newsletter的input元素,并将其选中  
  6.          $("input[name='newsletter']").attr("checked","checked");  
  7.         
  8.         //3)查找所有name属性不是newsletter的input元素,并将其选中  
  9.         $("input[name!='newsletter']").attr("checked","true"); //1  
  10.           
  11.           
  12.         //4)查找所有name属性以'news'开始的input元素,并将其选中  
  13.         $("input[name^='news']").attr("checked","true");  //3  
  14.           
  15.           
  16.         //5)查找所有name属性以'letter'结尾的input元素,并将其选中  
  17.         $("input[name$='letter']").attr("checked","true");   //2  
  18.           
  19.           
  20.         //6)查找所有name属性包含'news'的input元素,并将其选中  
  21.          $("input[name*='news']").attr("checked","true");   //3  
  22.           
  23.           
  24.         //7)找到所有含有id属性,并且它的name属性是以"letter"结尾的input元素,并将其选中  
  25.         $("input[id][name$='letter']").attr("checked","true");   
2.7 子元素选择器

[javascript]  view plain  copy
 print ?
  1. //1)迭代[each]每个ul中第1个li元素中的内容,索引从1开始  
  2.         $("ul li:first-child").each(function(){  
  3.             alert($(this).text());  
  4.         });  
  5.           
  6.           
  7.         //2)迭代每个ul中最后1个li元素中的内容,索引从1开始  
  8.         $("ul li:last-child").each(function(){  
  9.             alert($(this).text());  
  10.         });  
  11.           
  12.           
  13.         //3)在ul中查找是唯一子元素的li元素的内容  
  14.         $("ul li:only-child").each(function(){  
  15.             alert($(this).text());  
  16.         });  
  17.           
  18.           
  19.         //4)迭代每个ul中第2个li元素中的内容,索引从1开始  
  20.         $("ul li:nth-child(2)").each(function(){  
  21.             alert($(this).text());  
  22.         });  

2.8 表单选择器

[javascript]  view plain  copy
 print ?
  1. //1)查找所有input元素的个数  
  2.         alert($("input").size());  //10  
  3.         alert($(":input").size());  //13  
  4.           
  5.         //2)查找所有文本框的个数  
  6.         alert($(":text").size());  //1  
  7.           
  8.         //3)查找所有密码框的个数  
  9.         alert($(":password").size());  //1  
  10.           
  11.         //4)查找所有单选按钮的个数  
  12.         alert($(":radio").size());  
  13.           
  14.         //5)查找所有复选框的个数  
  15.         alert($(":checkbox").size());  
  16.           
  17.         //6)查找所有提交按钮的个数  
  18.         alert($(":submit").size());  
  19.           
  20.           
  21.         //7)匹配所有图像域的个数  
  22.         alert($(":images").size());  
  23.           
  24.           
  25.         //8)查找所有重置按钮的个数  
  26.         alert($(":reset").size());  
  27.           
  28.         //9)查找所有普通按钮的个数  
  29.         alert($(":button").size());  
  30.           
  31.         //10)查找所有文件域的个数  
  32.         alert($(":file").size());  //1  
  33.           
  34.           
  35.         //11)查找所有input元素为隐藏域的个数  
  36.         alert($(":input:hidden").size());  //1  

2.9 表单对象属性选择器

[javascript]  view plain  copy
 print ?
  1. //1)查找所有可用的input元素的个数  
  2.         alert($("input:enabled").size());  
  3.           
  4.         //2)查找所有不可用的input元素的个数  
  5.         alert($("input:disabled").size());  
  6.           
  7.         //3)查找所有选中的复选框元素的个数  
  8.         alert($(":checkbox:checked").size());  
  9.           
  10.         //4)查找所有未选中的复选框元素的个数  
  11.             alert($(":checkbox:not(:checked)").size());  
  12.           
  13.         //5)查找所有选中的选项元素的个数  
  14.         alert($("select option:selected").size());  
  15.         alert($("#provinceID  option:not(:selected)").size());  

三、JQuery的方法API的使用


jquery的方法非常多,其实都挺简单的,使用jquery大大降低了开发难度。该部分内容在下载的文件中的\JQuery\WebRoot\method目录中。

 each():是jQuery中专用于迭代数组的方法,参数为一个处理函数,this表示当前需要迭代的js对象

 append():追加到父元素之后

prepend():追加到父元素之前

after():追加到兄弟元素之后

 before():追加到兄弟元素之前

attr(name):获取属性值

 attr(name,value):给符合条件的标签添加key-value属性对

$("<div id='xxID'>HTML代码</div>"):创建元素,属性,文本   

 remove():删除自已及其后代节点 

val():获取value属性的值

 val(""):设置value属性值为""空串,相当于清空

text():获取HTML或XML标签之间的值

 text(""):设置HTML或XML标签之间的值为""空串

clone():只复制样式,不复制行为

clone(true):既复制样式,又复制行为

replaceWith():替代原来的节点

removeAttr():删除已存在的属性

addClass():增加已存在的样式

 removeClass():删除已存在的样式

 hasClass():判断标签是否有指定的样式,true表示有样式,false表示无样式

toggleClass():如果标签有样式就删除,否则增加样式

offset():获取对象的left和top坐标

offset({top:100,left:200}):将对象直接定位到指定的left和top坐标

width():获取对象的宽

width(300):设置对象的宽

height():获取对象的高

height(500):设置对象的高

children():只查询子节点,不含后代节点

 next():下一下兄弟节点

prev():上一下兄弟节点

siblings():上下兄弟节点

show():显示对象

 hide():隐藏对象

fadeIn():淡入显示对象

 fadeOut():淡出隐藏对象

slideUp():向上滑动

slideDown():向下滑动

slideToggle():上下切换滑动,速度快点

下面来看一些实例:

1、关于循环:

[javascript]  view plain  copy
 print ?
  1. //用JSON语法创建一个一维数组,存入object类型的编号和姓名,再迭代  
  2.         var nameArray=[  
  3.             {id:1,name:"张三 "},  
  4.             {id:2,name:"王明" },  
  5.             {id:3,name:"李水" }  
  6.           
  7.         ];  
  8.         var _nameArray=$(nameArray);  
  9.           
  10.         _nameArray.each(function(){  
  11.             //this代表object类型  
  12.             alert(this.id+":"+this.name);  
  13.           
  14.         });  
2、子元素插入到父元素内

[javascript]  view plain  copy
 print ?
  1. //DIV标签插入到UL标签之后(父子关系)  
  2.         $("ul").append($("div"));  
  3.           
  4.           
  5.         //DIV标签插入到UL标签之前(父子关系)  
  6.           
  7.         $("ul").prepend($("div"));  
3、子元素插入到父元素外

[javascript]  view plain  copy
 print ?
  1. //DIV标签插入到UL标签之后(兄弟关系)  
  2.         $("ul").after($("div"));  
  3.           
  4.           
  5.         //DIV标签插入到UL标签之前(兄弟关系)  
  6.           
  7.         $("ul").before($("div"));  
4、获取属性

[javascript]  view plain  copy
 print ?
  1. //取得form里第一个input元素的type属性  
  2.     alert($("form input:first").attr("type"));  //text  
  3.       
  4.     //设置form下最后一个input元素的为只读文本框  
  5.     $("form input:last").attr("readonly","readonly");   
  6.       
  7.     $(":password").attr("readonly","readonly");   
  8.       
  9.     //获取密码框的值  
  10.     alert($(":password").val());   
5、创建元素

[javascript]  view plain  copy
 print ?
  1. //创建div元素,添加"哈哈"文本,ID属性,并添加到文档中  
  2.           
  3.         //js方式  
  4.          var divElement=document.createElement("div");  
  5.         divElement.innerHTML="哈哈";  
  6.         divElement.setAttribute("id","2016");  
  7.         //document.getElementsByTagName("body")[0].appendChild(divElement);  
  8.         document.body.appendChile(divElement);  
  9.            
  10.           
  11.         //jquery方式  
  12.         var _div=$("<div id='2016'>哈哈</div>");  
  13.     //  $("body").append(_div);  
  14.           
  15.         $(document.body).append(_div);  
6、删除元素

[javascript]  view plain  copy
 print ?
  1. //删除ID为secondID的LI元素  
  2.         $("#secondID").remove();  
  3.           
  4.         //删除所有LI元素  
  5.         $("ul li").remove();  
  6.           
  7.         //删除UL元素  
  8.         $("ul").remove();  
  9.         //$(""#b").remove();  
7、获取文本内容

[javascript]  view plain  copy
 print ?
  1. //取得<div>中的内容  
  2.         alert($("div").text());  
  3.           
  4.         //取得<option>的值和描述  
  5.         var _option=$("#city option");  
  6.         var value=_option.val();  
  7.         var text=_option.text();  
  8.         alert(value+":"+text);  
8、复制元素

[javascript]  view plain  copy
 print ?
  1. //复制原input元素,添加到原input元素后,与其同级  
  2.         var _old=$(":button");  
  3.         var _new=_old.clone();  //在内存中  
  4.         _new.val("新按钮");  //无参代表取值,有参代表赋值  
  5.         _old.after(_new);  
  6.           
  7.         //为原input元素动态添加单击事件,且复制原input元素,  
  8.         var _old=$(":button");  
  9.         _old.click(function(){  
  10.             alert("动态事件");  
  11.           
  12.         });  
  13.           
  14.         //添加到原input元素后,与其同级,且和原按钮有一样的行为  
  15.         var _new=_old.clone();  
  16.         _new.val("新按钮");  
  17.         _old.after(_new);  
9、替换元素

[javascript]  view plain  copy
 print ?
  1. //双击<div>中的文本,用文本框替换文本  
  2.         $("div").dblclick(function(){  
  3.             var _text=$("<input type='text'  style='width:165px;height:23px'  />");  
  4.             //文本框替代文本框标签  
  5.             $(this).replaceWith(_text);  
  6.               
  7.         });  
10、删除属性

[javascript]  view plain  copy
 print ?
  1. //为<table>元素添加属性border/align/width  
  2.         $("table").attr("border","2").attr("align","center").attr("width","40%");  
  3.           
  4.           
  5.         //将<table>元素的align属性删除  
  6.         $("table").removeAttr("align");  
11、添加样式

[javascript]  view plain  copy
 print ?
  1. //为无样式的DIV添加样式  
  2.         $("div:first").addClass("myClass");  
  3.           
  4.         //为有样式的DIV删除样式  
  5.         $("div:last").removeClass("myClass");  
  6.           
  7.         //切换样式,即有样式的变成无样式,无样式的变成有样式  
  8.         $("div").toggleClass("myClass");  
  9.           
  10.         //最后一个DIV是否有样式  
  11.         var flag=$("div:last").hasClass("myClass");  
  12.         alert(flag?"有":"无");  
12、获取坐标,坐标设置

[java]  view plain  copy
 print ?
  1. //获取图片的坐标  
  2.         var offset=$("img").offset();  
  3.         var x=offset.top;  
  4.         var y=offset.left;  
  5.         alert(x+":"+y);  
  6.           
  7.           
  8.         //设置图片的坐标  
  9.         $("img").offset({  
  10.             top:200,  
  11.             left:200  
  12.           
  13.         });  
  14.           
  15.           
  16.         //获取图片的宽高  
  17.         var w=$("img").width();  
  18.         var h=$("img").height();  
  19.         alert(w+":"+h);  
  20.           
  21.           
  22.         //设置图片的宽高  
  23.         var w=$("img").width(500);  
  24.         var h=$("img").height(500);  
13、获取父元素的子元素
[javascript]  view plain  copy
 print ?
  1. //取得div元素的直接子元素内容,不含后代元素  
  2.         var _span=$("div").children();  
  3.         var content=_span.html();  
  4.         alert(content);  
  5.           
  6.         //取得div元素的下一个同级的兄弟元素内容    
  7.         var _p=$("div").next();     
  8.         alert(_p.text());  
  9.           
  10.         //取得div元素的上一个同级的兄弟元素内容  
  11.         var _p=$("div").prev();     
  12.         alert(_p.text());  
  13.           
  14.           
  15.         //依次取得div元素的上下一个同级的所有兄弟元素的内容  
  16.         var _all=$("div").siblings();  
  17.         _all.each(function(){  
  18.             alert($(this).text());  
  19.           
  20.         });  
  21.           
  22.         //只找p  
  23.             var _all=$("div").siblings("p");  
  24.         _all.each(function(){  
  25.             alert($(this).text());  
  26.           
  27.         });  
14、动画渐变(显示,隐藏)

[java]  view plain  copy
 print ?
  1. //图片隐蔽  
  2.         //$("img").hide(5000);  //5秒之后隐藏  
  3.           
  4.         //隐藏的动画结束后调用一个函数  
  5.         $("img").hide(5000,function(){  
  6.             alert("完成");  
  7.         });  
  8.           
  9.         //暂停3秒后继续隐藏  
  10.         window.setTimeout(function(){  
  11.               
  12.             $("img").show(5000);  
  13.           
  14.         },3000);  
  15.           
  16.           
  17.         //图片显示  
  18.         $("img").show(5000);  
15、图片的淡入淡出

[javascript]  view plain  copy
 print ?
  1. //淡入显示图片  
  2.         $("img").fadeIn(5000);  
  3.           
  4.         //淡出隐蔽图片  
  5.         $("img").fadeOut(5000);  
16、标签的滑动

[javascript]  view plain  copy
 print ?
  1. //向上下滑动  
  2.         $(":button").click(function(){  
  3.             //div标签上下移动  
  4.             $("div").slideToggle(1000);  
  5.           
  6.         });  

四、JQuery的事件API


1、页面加载
[javascript]  view plain  copy
 print ?
  1. //定义a()和b()二个方法  
  2.         function a(){  
  3.             alert("JS方式");  
  4.         }  
  5.         function b(){  
  6.             alert("JQUERY方式");  
  7.         }  
  8.         //使用JS方式加载a()和b()二个方法  
  9.         window.onload=function(){  
  10.             a();  
  11.             b();  
  12.         };   
  13.       
  14.         //使用jQuery方式加载a()和b()二个方法  
  15.         $(document).ready(function(){  
  16.             a();  
  17.             b();  
  18.         });  
  19.           
  20.           
  21.         //使用jQuery最简方式加载a()和b()二个方法  
  22.         $(function(){  
  23.             a();  
  24.             b();  
  25.           
  26.         });  
  27.         //js方式的onload与jquery方式的ready对比,ready更快。  
2、触发改变事件

[javascript]  view plain  copy
 print ?
  1. //当<select>标签触发onchange事件,显示选中<option>的value和innerHTML属性的值  
  2.         $("#city").change(function(){  
  3.             var $option=$("#city option:selected");  
  4.             var value=$option.val();  
  5.             var text=$option.text();  
  6.             alert(value+":"+text);  
  7.         });  
  8.           
3、获得焦点

[javascript]  view plain  copy
 print ?
  1. //加载页面时获取光标并选中所有文字  
  2.     $(function(){  
  3.         //光标定位文本框  
  4.         $(":text").focus();  
  5.         //选中文本框所有文本  
  6.         $(":text").select();  
  7.       
  8.     });  
4、按键事件

[javascript]  view plain  copy
 print ?
  1. //当按键弹起时,显示所按键的code码  
  2.     $(function(){  
  3.         $(document).keyup(function(){  
  4.             //获取按键的unicode编码  
  5.             var code=event.keyCode;  
  6.             alert(code);  
  7.         });  
  8.     });  

5、获得鼠标的移动事件

[javascript]  view plain  copy
 print ?
  1. //显示鼠标移动时的X和Y座标  
  2.       
  3.     $(function(){  
  4.         $(document).mousemove(function(){  
  5.             var x=event.clientX;  
  6.             var y=event.clientY;  
  7.             $("#xID").val(x);  
  8.             $("#yID").val(y);  
  9.               
  10.         });  
  11.     });  
6、mouseover和mouseout事件

[javascript]  view plain  copy
 print ?
  1. //鼠标移到某行上,某行背景变色  
  2.         $("table tr").mouseover(function(){  
  3.             $(this).css("background-color","pink");  
  4.         });  
  5.           
  6.         //鼠标移出某行,某行还原  
  7.         $("table tr").mouseout(function(){  
  8.             $(this).css("background-color","white");  
  9.         });  
  10.           
  11.         //鼠标移到某图片上,为图片加边框  
  12.         $("img").mouseover(function(){  
  13.             $(this).css("border-color","red");  
  14.           
  15.         });  
  16.           
  17.         //鼠标移出图片,图片还原  
  18.         $("img").mouseout(function(){  
  19.             $(this).css("border-color","white");  
  20.           
  21.         });  
7、submit事件

[javascript]  view plain  copy
 print ?
  1. <form action="06_mouseover_mouseout.html" method="post">  
  2.     用户名:<input type="text"/>  
  3.     <input type="submit" value="表单提交"/>  
  4. </form>  
  5.   
  6. <script type="text/javascript">  
  7.     //当表单提交前检测  
  8.     $(function(){  
  9.         //将光标定位于文本框中  
  10.         $(":text").focus();  
  11.   
  12.      });  
  13.       
  14.     $("form").submit(function(){  
  15.         var flag=false;  
  16.         //获取文本框中的内容  
  17.         var name=$(":text").val();  
  18.         //去掉两边空格  
  19.         name=$.trim(name);  
  20.           
  21.         if(name.length==0){  
  22.             alert("用户名不能为空");  
  23.             $(":text").focus();  
  24.             $(":text").val("");       
  25.               
  26.         }else{  
  27.               
  28.             flag=isChinese(name);  
  29.             //不是中文  
  30.             if(!flag){  
  31.                 alert("用户名必须是中文");  
  32.             }else{  
  33.                   
  34.             }  
  35.         }  
  36.         return flag;  
  37.     });  
  38.       
  39.     //检查是否为中文  
  40.     function isChinese(str){  
  41.         if(/^[\u4e00-\u9fa5]+$/.test(str)){  
  42.             return true;  
  43.         }else{  
  44.             return false;  
  45.         }  
  46.     }  
  47.       
  48. </script>  

  49. 关注QQ公众号【黑客联盟】学习更多黑客技术!   
  50.         
    关注微信公众号【国际黑客联盟】掌握最新国际技术动向!

你可能感兴趣的:(JQuery从0到大技术牛人学习之路!)