08--Web前端之jQuery
jquery介绍
jQuery是目前使用最广泛的javascript函数库。据统计,全世界排名前100万的网站,有46%使用jQuery,远远超过其他库。微软公司甚至把jQuery作为他们的官方库。
jQuery的版本分为1.x系列和2.x、3.x系列,1.x系列兼容低版本的浏览器,2.x、3.x系列放弃支持低版本浏览器,目前使用最多的是1.x系列的。
jquery是一个函数库,一个js文件,页面用script标签引入这个js文件就可以使用。
<script type="text/javascript" src="js/jquery-1.12.2.js"></script>
查看jQuery是否引入成功可用alert($)弹出:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Document</title> <script src="jquery-1.12.4.min.js"></script> <script> alert($); </script> </head> <body> </body> </html> 引入jQuery成功会在页面弹出:function (a,b){return new n.fn.init(a,b)}
jquery的口号和愿望 Write Less, Do More(写得少,做得多)
1、http://jquery.com/ 官方网站
2、https://code.jquery.com/ 版本下载
jquery加载
将获取元素的语句写到页面头部,会因为元素还没有加载而出错,jquery提供了ready方法解决这个问题,它的速度比原生的 window.onload 更快。
jquery初体验
用JS获取标签里面的内容
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Document</title> <script src="jquery-1.12.4.min.js"></script> <script> window.onload = function(){ var oA = document.getElementById("box"); alert(oA.innerHTML); } </script> </head> <body> <div id="box">今天天气还不错啊</div> </body> </html>
加上JQuery之后再与JS进行对比:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Document</title> <script src="jquery-1.12.4.min.js"></script> <script> window.onload = function(){ var oA = document.getElementById("box"); alert(oA.innerHTML); } $(document).ready(function(){ var $oA = $("#box"); alert($oA.html() + "这是JQuery的效果"); }) </script> </head> <body> <div id="box">今天天气还不错啊</div> </body> </html> 结论:jQuery的执行速度壁JS的更快!
在实际开发中,我们用的是jQuery的简写方式:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Document</title> <script src="jquery-1.12.4.min.js"></script> <script> $(function(){ var $oA = $("#box"); alert($oA.html() + "这是一个jQuery的效果"); }) </script> </head> <body> <div id="box">今天天气还不错啊</div> </body> </html>
jquery选择器
jquery用法思想:
选择某个网页元素,然后对它进行某种操作
jquery选择器
jquery选择器可以快速地选择元素,选择规则和css样式相同。
3个选择器举例:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Document</title>
<script src="jquery-1.12.4.min.js"></script>
<script>
$("#div1");
$(".box");
$(".list li");
</script>
</head>
<body>
<div id="div1">今天天气不错</div>
<div class="box">嗯,确实挺不错的</div>
<ul class="list">
<li>1</li>
<li>2</li>
<li>3</li>
<li>4</li>
</ul>
</body>
</html>
操作选择器选中的标签,改变其样式:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Document</title>
<script src="jquery-1.12.4.min.js"></script>
<script>
$(function(){
$("#div1").css({color:"red"});
$(".box").css({backgroundColor:"gold"});
$(".list li").css({color:"green",fontSize:"50px",backgroundColor:"pink",marginBottom:"3px"});
})
</script>
</head>
<body>
<div id="div1">今天天气不错</div>
<div class="box">嗯,确实挺不错的</div>
<ul class="list">
<li>1</li>
<li>2</li>
<li>3</li>
<li>4</li>
</ul>
</body>
</html>
jQuery基础选择器:
$(document) //选择整个文档对象 $('li') //选择所有的li元素 $('#myId') //选择id为myId的网页元素 $('.myClass') // 选择class为myClass的元素 $('input[name=first]') // 选择name属性等于first的input元素 $('#ul1 li span') //选择id为为ul1元素下的所有li下的span元素
对选择集进行修饰过滤(类似CSS伪类)
$('#ul1 li:first') //选择id为ul1元素下的第一个li
$('#ul1 li:odd') //选择id为ul1元素下的li的奇数行
$('#ul1 li:eq(2)') //选择id为ul1元素下的第3个li
$('#ul1 li:gt(2)') // 选择id为ul1元素下的前三个之后的li
$('#myForm :input') // 选择表单中的input元素
$('div:visible') //选择可见的div元素
对选择集进行函数过滤
$('div').has('p'); // 选择包含p元素的div元素
$('div').not('.myClass'); //选择class不等于myClass的div元素
$('div').filter('.myClass'); //选择class等于myClass的div元素
$('div').first(); //选择第1个div元素
$('div').eq(5); //选择第6个div元素
选择集转移
$('div').prev('p'); //选择div元素前面的第一个p元素
$('div').next('p'); //选择div元素后面的第一个p元素
$('div').closest('form'); //选择离div最近的那个form父元素
$('div').parent(); //选择div的父元素
$('div').children(); //选择div的所有子元素
$('div').siblings(); //选择div的同级元素
$('div').find('.myClass'); //选择div内的class等于myClass的元素
$().next()转移选择符:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Document</title> <script src="jquery-1.12.4.min.js"></script> <script> $(function(){ $("div").next().css({color:"red"}); }) </script> </head> <body> <div>今天天气不错</div> <p>确实挺好的啊</p> </body> </html>

浙公网安备 33010602011771号