概念
jQuery是一个JavaScript函数库。
jQuery是一个轻量级的"写的少,做的多"的JavaScript库。
jQuery库包含以下功能:
- HTML 元素选取
- HTML 元素操作
- CSS 操作
- HTML 事件函数
- JavaScript 特效和动画
- HTML DOM 遍历和修改
- AJAX
- Utilities
提示: 除此之外,jQuery还提供了大量的插件。目前网络上有大量开源的 JS 框架, 但是 jQuery 是目前最流行的 JS 框架,而且提供了大量的扩展。
安装
jQuery的版本:
jQuery版本有很多,分为1.x 2.x 3.x
1.x版本:能够兼容IE678浏览器
2.x版本:不兼容IE678浏览器
1.x和2.x版本jquery都不再更新版本了,现在只更新3.x版本。
3.x版本:不兼容IE678,更加的精简(在国内不流行,因为国内使用jQuery的主要目的就是兼容IE678)
国内多数网站还在使用1.x的版本
jQuery的下载
jQuery有两个版本:生成环境使用的和开发测试环境使用的。
Production version - 用于实际的网站中,已被精简和压缩。
Development version - 用于测试和开发(未压缩,是可读的代码)
以上两个版本都可以从 jquery.com 中下载。
jQuery的使用
jQuery 库是一个 JavaScript 文件,我们可以直接在 HTML页面中通过script 标签引用它,跟引用自己的 外部JavaScript脚本文件一样的语法。
<head> <script src="jquery-1.11.1.js"></script> </head>
jQuery语法结构
jQuery 语法是通过选取 HTML 元素,并对选取的元素执行某些操作(actions)。
基础语法: $(selector).action()
说明: 美元符号定义 jQuery
选择符(selector)"查询"和"查找" HTML 元素
jQuery 的 action() 执行对元素的操作
文档就绪事件
文档就绪事件,实际就是文件加载事件。
这是为了防止文档在完全加载(就绪)之前运行 jQuery 代码,即在 DOM 加载完成后才可以对 DOM 进行操作。
如果在文档没有完全加载之前就运行函数,操作可能失败。 所以我们尽可能将所有的操作都在文档加载完毕之后实现。
写法1: $(document).ready(function(){ // 开始写 jQuery 代码... }); 写法2:简介写法-推荐 $(function(){ // 开始写 jQuery 代码... });
jQuery的ready方法与JavaScript中的onload相似,但是也有区别:
window.onload | $(document).ready() | |
执 行 次 数 | 只能执行一次,如果执行第二次,第一次的 执行会被覆盖 | 可用执行多次,不会覆盖之前的执行 |
执 行 时 机 | 必须等待网页全部加载挖完毕(包括图片 等),然后再执行包裹的代码 | 只需要等待网页中的DOM结果加载完 毕就可以执行包裹的代码 |
简 写 方 式 | 无 | $(function(){ }); |
jQuery选择器
jQuery 选择器基于元素的 id、类、类型、属性、属性值等"查找"(或选择)HTML 元素。
它基于已经 存在的 CSS 选择器,除此之外,它还有一些自定义的选择器。
jQuery 中所有选择器都以美元符号开头:$()。
<script> //1、标签选择器: function htmlSelector(){ //获取所有的div元素(集合) var divList=$("div"); console.log(divList);//jQuery的对象 console.log(divList.length); for(var i=0;i<divList.length;i++){ console.log(divList[i]);//js的对象 //将js对象转换为jQuery的对象 console.log($(divList[i])); } } //2、id选择器 function idSelector(){ //根据id获取到的元素是惟一的,即使页面上有重名的id,获取的是第一个 var p=$("#p1"); console.log(p.html()); } //3、.class选择器 function classSelector(){ var list=$(".mydiv"); console.log(list.length); } //4、 全局选择器 function allSelector(){ var list=$("*");//包括了html、head、title.....所有标签 console.log(list.length); for(var i=0;i<list.length;i++){ console.log(list[i]);//js的对象 } } //5、并集选择器 function andSelector(){ var list=$(".mydiv,p,li"); printList(list); } //6、后代选择器:包括所有的后代,儿子和孙子辈都有 function subSelector(){ var list=$("form input"); printList(list); } //7、子选择器:只有子元素 function sunSelector(){ var list=$("form>input"); printList(list); } //8、相邻选择器 function nextSelector(){ var list=$("label + input"); printList(list); } //9、同辈选择器 function sublingsSelector(){ var list=$("form ~ div"); printList(list); } //10、属性选择器 function attrSelector(){ var list=$("div[id]");//获取所有有id属性的div的元素集合 list=$("div[class]");//获取所有有class属性的div的元素集合 list=$("input[name=‘userName‘]");//获取所有input标签中name属性是userName元素的集合 list=$("input[name^=‘user‘]");//获取所有input标签中name属性是user开头的元素的集合 list=$("input[name$=‘user‘]");//获取所有input标签中name属性是user结尾的元素的集合 list=$("input[name*=‘user‘]");//获取所有input标签中name属性包含了user的元素的集合 list=$("input[id][name^=‘user‘]");//获取所有input标签中既有id属性又有name属性以user开头的元素的集合 printList(list); } //11、可见性选择器 function seeSelector(){ //匹配所有的可见div元素 var list=$("div:visible"); //匹配所有的不可见div元素 var list=$("div:hidden"); //匹配所有的不可见input元素,样式有display:none的元素和type=hidden的元素 list=$("input:hidden"); printList(list); } //文档就绪事件:页面加载完毕之后执行: $(function(){ seeSelector(); }); </script>
jQuery常用函数
与标签内容相关函数
与标签属性相关函数
与标签样式相关函数
<script> //1、与标签内容相关函数 function textFun(){ var str1=$("div").html();//获取的是第一个匹配元素的围堵标签中的内容,包含了嵌套在内容的标签的内容 console.log(str1); var str2=$("div").text();//获取的是所有匹配元素的标签中的文本信息,不包含标签内容 console.log(str2); var str3=$("div").val();//val()只能获取到表单项元素的值,div不是表单元素,所有获取不到 console.log(str3); var str4=$("input").val();//获取的是第一个匹配表单元素的value值,input是表单元素,所以可以获取到值 console.log(str4); } //2、与属性相关的函数 function attrFun(){ var img=$("img"); //设置属性 img.attr("src","img/cat.jpg"); img.attr("title","不服!"); //移除属性 img.removeAttr("title"); //获取属性 var src=img.attr("src"); var title=img.attr("title"); console.log(src+"===="+title); //获取checked属性使用prop函数,获取到的值是boolean类型,表示十分被选中 var list=$("input[type=‘radio‘]"); for(var i=0;i<list.length;i++){ var flag=$(list[i]).prop("checked"); console.log("checked="+flag); } } //3、与css相关的函数 function cssFun(){ //给获取的元素添加、删除、切换已有的样式 PS:样式一定是在样式表中提前定义好的 $("div").addClass("redBg"); $("div").addClass("redBg fontColor"); $("div").removeClass("fontColor"); $("div").removeClass();//没有参数的时候直接移除所有的样式 //$("div").toggleClass("fontColor");//匹配元素如果有当前的样式就删除,如果没有就添加 //给所有的元素添加样式,样式直接添加,无需提前定义 $("input").css("border-color","blue"); $("input").css({"color":"red","border-color":"green"}); } </script>
jQuery中的事件
页面对不同访问者的响应叫做事件。事件处理程序指的是当 HTML 中发生某些事件时所调用的方法。
常用DOM事件列表
鼠标事件 | 键盘事件 | 表单事件 | 件 文档/窗口事件 |
click | keydown | submit | load |
dblclick | keyup | change | |
mouseover | focus | ||
mouseout | blur | ||
hover |
常用的 jQuery 事件方法
在 jQuery 中,大多数 DOM 事件都有一个等效的 jQuery 方法。
<script> //页面加载事件 $(function(){ //给所有的button绑定单击事件 $("button").click(function(){ //alert(this);//this是当前对象,哪个按钮触发的单击事件this就是那个按钮,this此时是JS对象 $(this).css("color","red");//给当前的触发对象添加一个css }); //给所有的超链接绑定鼠标移上事件 $("a").mouseover(function(){ var str=$(this).html(); $(this).html("鼠标移上-"+str); }); //给所有的超链接绑定鼠标移出事件 $("a").mouseout(function(){ var str=$(this).html(); $(this).html(str.substr(5)); }); $("a").hover(function(){ $(this).css("color","red"); }); }); </script>
jQuery操作DOM
元素的增加
- append() - 在被选元素的结尾插入内容
- prepend() - 在被选元素的开头插入内容
- after() - 在被选元素之后插入内容
- before() - 在被选元素之前插入内容
<script> $(function(){ // append() - 在被选元素的结尾插入内容 $("#btn1").click(function(){ $("div").append("<br/>新添加的文本<br/>"); $("div").append("<p>新添加的段落</p>"); }); //prepend() - 在被选元素的开头插入内容 $("#btn2").click(function(){ $("div").prepend("<br/>新添加的文本<br/>"); $("div").prepend("<p>新添加的段落</p>"); }); //after() - 在被选元素之后插入内容 $("#btn3").click(function(){ $("div").after("<br/>新添加的文本<br/>"); $("div").after("<p>新添加的段落</p>"); }); //before() - 在被选元素之前插入内容 $("#btn4").click(function(){ $("div").before("<br/>新添加的文本<br/>"); $("div").before("<p>新添加的段落</p>"); }); }); </script>
元素的克隆
clone(boolean)-克隆匹配的DOM元素并且选中这些克隆的副本
语法:$(selector).clone(includeEvents);
参数:可选。布尔值。规定是否复制元素的所有事件处理。默认地,副本中不包含事件处理器。
<script> $(function(){ $("#btn3").click(function(){ alert("试试就试试!"); }); // clone(true) $("#btn1").click(function(){ $("p").clone(true).appendTo("div"); }); //clone(false) $("#btn2").click(function(){ $("p").clone(false).appendTo("div"); }); }); </script>
元素的替换
- replaceWith() -将所有匹配的元素替换成指定的HTML或DOM元素。
- replaceAll()-用匹配的元素替换掉所有 selector匹配到的元素。
<script> $(function(){ //replaceWith() -将所有匹配的元素替换成指定的HTML或DOM元素。 $("#btn1").click(function(){ //$("div").replaceWith("<br/>新替换的文本<br/>"); $("div").replaceWith("<p>新替换的段落</p>");//所有的div被后面的参数替换掉 }); //replaceAll()-用匹配的元素替换掉所有 selector匹配到的元素。 $("#btn2").click(function(){ $("<div>新的div</div>").replaceAll("p");//用前面的内容替换掉所有的段落p }); }); </script>
元素的删除
- remove() - 删除被选元素(及其子元素)
- empty() - 从被选元素中删除子元素
<script> $(function(){ //remove() - 删除被选元素(及其子元素) $("#btn1").click(function(){ $("div").remove();//所有的div元素及其子元素被删除 }); //remove(筛选条件) - 删除符合筛选条件的元素 $("#btn2").click(function(){ $("div").remove(".test");//所有的div元素中引用了class="test"的div被删除 }); //empty() - 从被选元素中删除子元素 $("#btn3").click(function(){ $("div").empty();//删除div中的所有子元素 }); }); </script>
jQuery效果
隐藏和显示
语法:
-
- $(selector).hide([speed,callback]);
- $(selector).show([speed,callback]);
- $(selector).toggle([speed,callback]);
参数说明: 可选的 speed 参数规定隐藏/显示的速度,可以取以下值:"slow"、"fast" 或毫秒。
可选的 callback 参数是隐藏或显示完成后所执行的函数名称。
<script> $(function(){ $("#btnHide").click(function(){ //$("div").hide(); //$("div").hide(2000); $("div").hide(2000,function(){ alert("隐藏完成!"); }); }); $("#btnShow").click(function(){ //$("div").show(); //$("div").show(2000); $("div").show(2000,function(){ alert("显示完成!"); }); }); $("#btnToggle").click(function(){ //$("p").toggle(); //$("p").toggle(2000); $("p").toggle(2000,function(){ alert("切换完成!"); }); }); }); </script>
淡入和淡出
语法:
-
- $(selector).fadeIn([speed,callback]);
- $(selector).fadeOut([speed,callback]);
- $(selector).fadeToggle([speed,callback]);
参数说明: 可选的 speed 参数规定隐藏/显示的速度,可以取以下值:"slow"、"fast" 或毫秒。
可选的 callback 参数是隐藏或显示完成后所执行的函数名称。
<script> $(function(){ $("#btnIn").click(function(){ //$("div").fadeIn(); //$("div").fadeIn(2000); $("div").fadeIn(2000,function(){ alert("淡入完成!"); }); }); $("#btnOut").click(function(){ //$("div").fadeOut(); //$("div").fadeOut(2000); $("div").fadeOut(2000,function(){ alert("淡出完成!"); }); }); $("#btnToggle").click(function(){ //$("p").fadeToggle(); //$("p").fadeToggle(2000); $("p").fadeToggle(2000,function(){ alert("切换完成!"); }); }); }); </script>