本文最初發表於 "博客園" ,併在 "GitHub" 上持續更新 前端的系列文章 。歡迎在GitHub上關註我,一起入門和進階前端。 以下是正文。 jQuery 的介紹 引入 jQuery 的原因 在用 js 寫代碼時,會遇到一些問題: window.onload 事件有事件覆蓋的問題,因此只能寫一 ...
以下是正文。
jQuery 的介紹
引入 jQuery 的原因
在用 js 寫代碼時,會遇到一些問題:
window.onload 事件有事件覆蓋的問題,因此只能寫一個事件。
代碼容錯性差。
瀏覽器相容性問題。
書寫很繁瑣,代碼量多。
代碼很亂,各個頁面到處都是。
動畫效果很難實現。
如下圖所示:
jQuery的出現,可以解決以上問題。
什麼是 jQuery
jQuery 是 js 的一個庫,封裝了我們開發過程中常用的一些功能,方便我們調用,提高開發效率。
js庫是把我們常用的功能放到一個單獨的文件中,我們用的時候,直接引用到頁面里即可。
以下是jQuery的相關信息:
官網API文檔:http://api.jquery.com/
漢化API文檔:http://www.css88.com/jqapi-1.9/
學習jQuery,主要是學什麼
初期,主要學習如何使用jQuery操作DOM,其實就是學習jQuery封裝好的那些功API。
這些API的共同特點是:幾乎全都是方法。所以,在使用jQuery的API時,都是方法調用,也就是說要加小括弧(),小括弧裡面是相應的參數,參數不同,功能不同。
jQuery初體驗
現在用原生 js 來寫下麵這一段代碼:
<!DOCTYPE html>
<html>
<head lang="en">
<meta charset="UTF-8">
<title></title>
<style>
div {
height: 100px;
background-color: pink;
margin: 10px;
display: none;
}
</style>
<script>
//原生js
window.onload = function () {
var btn = document.getElementsByTagName("button")[0];
var divArr = document.getElementsByTagName("div");
btn.onclick = function () {
for (var i = 0; i < divArr.length; i++) {
divArr[i].style.display = "block";
divArr[i].innerHTML = "生命壹號";
}
}
}
</script>
</head>
<body>
<button>顯示五個div盒子和設置內容</button>
<div></div>
<div></div>
<div></div>
<div></div>
<div></div>
</body>
</html>
如果用 jQuery 來寫,保持其他的代碼不變,<script>
部分的代碼修改為:(需要提前引入 )
<script src="jquery-1.11.1.js"></script>
<script>
//jquery版
$(document).ready(function () {
//獲取元素
var jQbtn = $("button");//根據標簽名獲取元素
var jQdiv = $("div");//根據標簽名獲取元素
//綁定事件
jQbtn.click(function () {
jQdiv.show(1000);//顯示盒子。
jQdiv.html("tomorrow!");//設置內容
//上面的兩行可以寫成鏈式編程:jQdiv.show(3000).html(1111);
});//事件是通過方法綁定的。
});
</script>
jQuery 的兩大特點
鏈式編程:比如
.show()
和.html()
可以連寫成.show().html()
。隱式迭代:隱式 對應的是 顯式。隱式迭代的意思是:在方法的內部進行迴圈遍歷,而不用我們自己再進行迴圈,簡化我們的操作,方便我們調用。
jQuery 的使用
使用 jQuery 的基本步驟
(1)引包
(2)入口函數
(3)功能實現代碼(事件處理)
如下圖所示:
主要,導包的代碼一定要放在js代碼的最上面。
jQuery 的版本
jQuery 有兩個大版本:
1.x版本:最新版為 v1.11.3。
2.x版本:最新版為 v2.1.4(不再支持IE6、7、8)。
3.x版本。
我們以 v1.11.1版本為例,下載下來後發現,裡面有兩個文件:
它們的區別是:
第一個是未壓縮版,第二個是壓縮版。
平時開發過程中,可以使用任意一個版本;但是,項目上線的時候,推薦使用壓縮版。
jQuery 的入口函數和 $
符號
入口函數(重要)
原生 js 的入口函數指的是:window.onload = function() {};
如下:
//原生 js 的入口函數。頁面上所有內容載入完畢,才執行。
//不僅要等文本載入完畢,而且要等圖片也要載入完畢,才執行函數。
window.onload = function () {
alert(1);
}
而 jQuery的入口函數,有以下幾種寫法:
寫法一:
//1.文檔載入完畢,圖片不載入的時候,就可以執行這個函數。
$(document).ready(function () {
alert(1);
})
寫法二:(寫法一的簡潔版)
//2.文檔載入完畢,圖片不載入的時候,就可以執行這個函數。
$(function () {
alert(1);
});
寫法三:
//3.文檔載入完畢,圖片也載入完畢的時候,在執行這個函數。
$(window).ready(function () {
alert(1);
})
jQuery入口函數與js入口函數的區別:
區別一:書寫個數不同:
Js 的入口函數只能出現一次,出現多次會存在事件覆蓋的問題。
jQuery 的入口函數,可以出現任意多次,並不存在事件覆蓋問題。
區別二:執行時機不同:
Js的入口函數是在所有的文件資源載入完成後,才執行。這些文件資源包括:頁面文檔、外部的js文件、外部的css文件、圖片等。
jQuery的入口函數,是在文檔載入完成後,就執行。文檔載入完成指的是:DOM樹載入完成後,就可以操作DOM了,不用等到所有的外部資源都載入完成。
文檔載入的順序:從上往下,邊解析邊執行。
jQuery的$
符號
jQuery 使用 $
符號原因:書寫簡潔、相對於其他字元與眾不同、容易被記住。
jQuery占用了我們兩個變數:$
和 jQuery。當我們在代碼中列印它們倆的時候:
<script src="jquery-1.11.1.js"></script>
<script>
console.log($);
console.log(jQuery);
console.log($===jQuery);
</script>
列印結果如下:
從列印結果可以看出,$ 代表的就是 jQuery。
那怎麼理解jQuery裡面的 $
符號呢?
$
實際上表示的是一個函數名 如下:
$(); // 調用上面我們自定義的函數$
$(document).ready(function(){}); // 調用入口函數
$(function(){}); // 調用入口函數
$(“#btnShow”) // 獲取id屬性為btnShow的元素
$(“div”) // 獲取所有的div標簽元素
如上方所示,jQuery 裡面的 $
函數,根據傳入參數的不同,進行不同的調用,實現不同的功能。返回的是jQuery對象。
jQuery這個js庫,除了$
之外,還提供了另外一個函數:jQuery。jQuery函數跟 $
函數的關係:jQuery === $
。
js中的DOM對象 和 jQuery對象 比較(重點,難點)
二者的區別
通過 jQuery 獲取的元素是一個數組,數組中包含著原生JS中的DOM對象。舉例:
針對下麵這樣一個div結構:
<div></div>
<div class="box"></div>
<div id="box"></div>
<div class="box"></div>
<div></div>
通過原生 js 獲取這些元素節點的方式是:
var myBox = document.getElementById("box"); //通過 id 獲取單個元素
var boxArr = document.getElementsByClassName("box"); //通過 class 獲取的是數組
var divArr = document.getElementsByTagName("div"); //通過標簽獲取的是數組
通過 jQuery 獲取這些元素節點的方式是:(獲取的都是數組)
//獲取的是數組,裡面包含著原生 JS 中的DOM對象。
var jqBox1 = $("#box");
var jqBox2 = $(".box");
var jqBox3 = $("div");
我們列印出來看看:
上圖顯示,由於JQuery 自帶了 css()方法,我們還可以直接在代碼中給 div 設置 css 屬性。
總結:jQuery 就是把 DOM 對象重新包裝了一下,讓其具有了 jQuery 方法。
二者的相互轉換
1、 DOM 對象 轉為 jQuery對象:
$(js對象);
舉例:(拿上一段的代碼舉例)
//轉換。
jqBox1 = $(myBox);
jqBox2 = $(boxArr);
jqBox3 = $(divArr);
DOM 對象轉換成了 jquery 對象之後,皮上面的功能可以直接調用。
2、jQuery對象 轉為 DOM 對象:
jquery對象[index]; //方式1(推薦)
jquery對象.get(index); //方式2
jQuery對象轉換成了 DOM 對象之後,可以直接調用 DOM 提供的一些功能。如:
//jquery對象轉換成 DOM 對象之後
jqBox3[0].style.backgroundColor = "black";
jqBox3.get(4).style.backgroundColor = "pink";
總結:如果想要用哪種方式設置屬性或方法,必須轉換成該類型。
舉例:隔行變色
代碼如下:
<!DOCTYPE html>
<html>
<head lang="en">
<meta charset="UTF-8">
<title></title>
<script src="jquery-1.11.1.js"></script>
<script>
//入口函數
jQuery(function () {
var jqLi = $("li");
for (var i = 0; i < jqLi.length; i++) {
if (i % 2 === 0) {
//jquery對象,轉換成了js對象
jqLi[i].style.backgroundColor = "pink";
} else {
jqLi[i].style.backgroundColor = "yellow";
}
}
});
</script>
</head>
<body>
<ul>
<li>生命壹號,永不止步</li>
<li>生命壹號,永不止步</li>
<li>生命壹號,永不止步</li>
<li>生命壹號,永不止步</li>
<li>生命壹號,永不止步</li>
<li>生命壹號,永不止步</li>
<li>生命壹號,永不止步</li>
</ul>
</body>
</html>
效果如下:
jQuery 選擇器
我們以前在CSS中學習的選擇器有:
今天來學習一下jQuery 選擇器。
jQuery選擇器是jQuery強大的體現,它提供了一組方法,讓我們更加方便的獲取到頁面中的元素。
1、jQuery 的基本選擇器
解釋如下:
舉例:
<!DOCTYPE html>
<html>
<head lang="en">
<meta charset="UTF-8">
<title></title>
<script src="jquery-1.11.1.js"></script>
<script>
//入口函數
jQuery(document).ready(function () {
//三種方式獲取jquery對象
var jqBox1 = $("#box");
var jqBox2 = $(".box");
var jqBox3 = $("div");
//操作標簽選擇器
jqBox3.css("width", 100);
jqBox3.css("height", 100);
jqBox3.css("margin", 10);
jqBox3.css("background", "pink");
//操作類選擇器(隱式迭代,不用一個一個設置)
jqBox2.css("background", "red");
//操作id選擇器
jqBox1.css("background", "yellow");
});
</script>
</head>
<body>
<div></div>
<div class="box"></div>
<div id="box"></div>
<div class="box"></div>
<div></div>
</body>
</html>
效果如下:
2、層級選擇器
解釋如下:
舉例:
<!DOCTYPE html>
<html>
<head lang="en">
<meta charset="UTF-8">
<title></title>
<script src="jquery-1.11.1.js"></script>
<script>
$(function () {
//獲取ul中的li設置為粉色
//後代:兒孫重孫曾孫玄孫....
var jqLi = $("ul li");
jqLi.css("margin", 5);
jqLi.css("background", "pink");
//子代:親兒子
var jqOtherLi = $("ul>li");
jqOtherLi.css("background", "red");
});
</script>
</head>
<body>
<ul>
<li>111</li>
<li>222</li>
<li>333</li>
<ol>
<li>aaa</li>
<li>bbb</li>
<li>ccc</li>
</ol>
</ul>
</body>
</html>
效果:
3、基本過濾選擇器
解釋:
舉例:
<script src="jquery-1.11.1.js"></script>
<script>
$(document).ready(function () {
// :odd
$("li:odd").css("background", "red");
// :even
$("li:even").css("background", "green");
// :eq(index)
$("ul li:eq(3)").css("font-size", "30px"); //設置第四個li的字體
// :lt(index)
$("li:lt(6)").css("font-size", "30px");
// :gt(index)
$(".ulList1 li:gt(7)").css("font-size", "40px");
// :first
$(".ulList li:first").css("font-size", "40px");
// :last
$("li:last").css("font-size", "40px");
});
</script>
4、屬性選擇器
5、篩選選擇器
舉例:
<!DOCTYPE html>
<html>
<head lang="en">
<meta charset="UTF-8">
<title></title>
<script src="jquery-1.11.1.js"></script>
<script>
jQuery(function () {
var jqul = $("ul");
//find(selector); 從jquery對象的後代中查找
//必須制定參數,如果不指定獲取不到元素。length === 0
jqul.find("li").css("background", "pink");
console.log(jqul.find());
//chidlren(selector); 從jquery對象的子代中查找
//不寫參數代表獲取所有子元素。
jqul.children("li").css("background", "green");
//eq(索引值); 從jquery對象的子代中查找該索引值的元素
//要寫該數組中的第幾個。
jqul.children().eq(0).css("background", "red");
//next(); 該元素的下一個兄弟元素
jqul.children().eq(0).next().css("background", "yellow");
//siblings(selector); 該元素的所有兄弟元素
jqul.children().eq(0).next().siblings().css("border", "1px solid blue");
//parent(); 該元素的父元素(和定位沒有關係)
console.log(jqul.children().eq(0).parent());
});
</script>
</head>
<body>
<ul>
<li>生命壹號,永不止步</li>
<li class="box">生命壹號,永不止步</li>
<span>生命壹號,永不止步</span>
<li class="box">生命壹號,永不止步</li>
<i>生命壹號,永不止步</i>
<li>生命壹號,永不止步</li>
<a id="box" href="#">生命壹號,永不止步</a>
<ol>
<li>我是ol中的li</li>
<li>我是ol中的li</li>
<li>我是ol中的li</li>
<li>我是ol中的li</li>
</ol>
</ul>
</body>
</html>
效果:
我的公眾號
想學習代碼之外的軟技能?不妨關註我的微信公眾號:生命團隊(id:vitateam
)。
掃一掃,你將發現另一個全新的世界,而這將是一場美麗的意外: