jQuery是什么
說白了jQuery是一個js庫
當然了除了這個庫之外,我們還有跟多的庫,比如:Prototype、YUI、Dojo、Ext JS、移動端的zepto等
目的就簡潔的,快速的開發
學習jQuery本質: 就是學習呼叫這些函式(方法),
1.jQuery的優點
- 輕量級,核心檔案才幾十kb,不會影響頁面加載速度,
- 跨瀏覽器兼容,基本兼容了現在主流的瀏覽器,
- 鏈式編程、隱式迭代,
- 對事件、樣式、影片支持,大大簡化了DOM操作,
- 支持插件擴展開發,有著豐富的第三方的插件,例如:樹形選單、日期控制元件、輪播圖等,
- 免費、開源,
2.jQuery如何使用呢?
- 首選你要去下載
- 在你的scrpit標簽中(末尾)引入這個檔案,當然了你也可以在加載的時候在頁面頭部引入,比如你使用windows.load.....,不過在jquer中有更好的解決方案
- 最簡單的使用
$('div').hide(),//隱藏盒子
特別要說明的一點是:jQuery有一些兼容的小問題,但.....你不用去管它
3.正式的開始使用它
3.1入口函式
這個就是一個人入口函式,相當于 DOMContentLoaded等待dom結構加載完再去執行js代碼
// 第一種: 簡單易用,
$(function () {
... // 此處是頁面 DOM 加載完成的入口
}) ;
// 第二種: 繁瑣,但是也可以實作
$(document).ready(function(){
... // 此處是頁面DOM加載完成的入口
});
3.2 $是什么?
\(是jQuery的頂級物件,\) 與 jQuery是等價的,
3.3 jQuery物件與DOM物件
DOM與jQuery是可以互相轉換的,用元素的js獲取的就是DOM物件,$ 獲取的就是一個jquery物件
- jQuery 物件本質是: 利用$對DOM 物件包裝后產生的物件(偽陣列形式存盤),
- 只有 jQuery 物件才能使用 jQuery 方法,DOM 物件則使用原生的 JavaScirpt 方法,
- 相互的轉換, 原生中的方法,
// 1.DOM物件轉換成jQuery物件,方法只有一種
var box = document.getElementById('box'); // 獲取DOM物件
var jQueryObject = $(box); // 把DOM物件轉換為 jQuery 物件
// 2.jQuery 物件轉換為 DOM 物件有兩種方法:
// 2.1 jQuery物件[索引值]
var domObject1 = $('div')[0]
// 2.2 jQuery物件.get(索引值)
var domObject2 = $('div').get(0)
3.4 獲取元素(選擇器)
- 獲取很簡單直接就是 $ 這個比較簡單,也叫 基礎選擇器,當然了,里面還有更多的操作功能

其實這個很簡單,跟css里面的語法很簡單的
- 層級選擇器
顧名思義 就是選擇具有層級關系的元素,主要就是兩個后代選擇器;
后代選擇器和子代選擇器,(親兒子選擇器和子子孫孫選擇器)
- 篩選選擇器
這里使用的時候,我們都是在站在父子兄的角度去分析的

3.5 設定樣式怎么搞?直接用封裝的函式
- 簡單的樣式
$('div').css('屬性', '值')
- jQuery里面的排它思想
// 想要多選一的效果,排他思想:當前元素設定樣式,其余的兄弟元素清除樣式,
$(this).css(“color”,”red”);
$(this).siblings(). css(“color”,””);
- 隱式迭代
所謂的隱式迭代指的就是 自動的遍歷dom元素
// 遍歷內部 DOM 元素(偽陣列形式存盤)的程序就叫做隱式迭代,
// 簡單理解:給匹配到的所有元素進行回圈遍歷,執行相應的方法,而不用我們再進行回圈,簡化我們的操作,方便我們呼叫,
$('div').hide(); // 頁面中所有的div全部隱藏,不用回圈操作
- 鏈式編程?(很重要!!!!)
$(this).css('color', 'red').sibling().css('color', '');
3.5 有沒有更好的樣式操作呢?
在juqery中,樣式的操作主要的就是有兩種css() 還有就是設定樣式
- css(),用來簡單的處理樣式,主要有三種使用形式,當然了也可以拿來操作;類
// 1.引數只寫屬性名,則是回傳屬性值
var strColor = $(this).css('color');
// 2. 引數是屬性名,屬性值,逗號分隔,是設定一組樣式,屬性必須加引號,值如果是數字可以不用跟單位和引號
$(this).css(''color'', ''red'');
// 3. 引數可以是物件形式,方便設定多組樣式,屬性名和屬性值用冒號隔開, 屬性可以不用加引號
$(this).css({ "color":"white","font-size":"20px"});
- 設定樣式,在實際的開發中比較常用
//比如我現在有幾個樣式在css中
.current{
color:#ffff;
}
$("div").addClass("current");
// 2.洗掉類
$("div").removeClass("current");
// 3.切換類
$("div").toggleClass("current");
- 特別需要說明的是:
原生 JS 中 className 會覆寫元素原先里面的類名,jQuery 里面類操作只是對指定類進行操作,不影響原先的類名,哈哈哈jQuery確實是比較強大的
3.6 jquery里面影片特效呢?
首先我們來看一下這里的這個簡單的表格
- 顯示隱藏:show() / hide() / toggle() ;
- 劃入畫出:slideDown() / slideUp() / slideToggle() ;
- 淡入淡出:fadeIn() / fadeOut() / fadeToggle() / fadeTo() ;
- 自定義影片:animate() ;
小心!影片或者效果一旦觸發就會執行,如果多次觸發,就造成多個影片或者效果排隊執行,我們可以是喲jQuery中的另一個方法,停止影片排隊stop()
- 效果-顯示隱藏
常見有三個方法:show() / hide() / toggle() ;
?語法規范如下:

代碼演示
<body>
<button>顯示</button>
<button>隱藏</button>
<button>切換</button>
<div></div>
<script>
$(function() {
$("button").eq(0).click(function() {
$("div").show(1000, function() {
alert(1);
});
})
$("button").eq(1).click(function() {
$("div").hide(1000, function() {
alert(1);
});
})
$("button").eq(2).click(function() {
$("div").toggle(1000);
})
// 一般情況下,我們都不加引數直接顯示隱藏就可以了
});
</script>
</body>
- 效果-滑入滑出
常見有三個方法:slideDown() / slideUp() / slideToggle() ;
語法規范如下:

代碼示例:
<body>
<button>下拉滑動</button>
<button>上拉滑動</button>
<button>切換滑動</button>
<div></div>
<script>
$(function() {
$("button").eq(0).click(function() {
// 下滑動 slideDown()
$("div").slideDown();
})
$("button").eq(1).click(function() {
// 上滑動 slideUp()
$("div").slideUp(500);
})
$("button").eq(2).click(function() {
// 滑動切換 slideToggle()
$("div").slideToggle(500);
});
});
</script>
</body>
- 效果-淡入淡出
常見有四個方法:fadeIn() / fadeOut() / fadeToggle() / fadeTo() ;


示例代碼:
<body>
<button>淡入效果</button>
<button>淡出效果</button>
<button>淡入淡出切換</button>
<button>修改透明度</button>
<div></div>
<script>
$(function() {
$("button").eq(0).click(function() {
// 淡入 fadeIn()
$("div").fadeIn(1000);
})
$("button").eq(1).click(function() {
// 淡出 fadeOut()
$("div").fadeOut(1000);
})
$("button").eq(2).click(function() {
// 淡入淡出切換 fadeToggle()
$("div").fadeToggle(1000);
});
$("button").eq(3).click(function() {
// 修改透明度 fadeTo() 這個速度和透明度要必須寫
$("div").fadeTo(1000, 0.5);
});
});
</script>
</body>
- 效果-自定義影片(功能非常的強大)
通過引數的傳遞可以模擬以上所有影片,方法為:animate() ;
語法規范:

<body>
<button>動起來</button>
<div></div>
<script>
$(function() {
$("button").click(function() {
$("div").animate({
left: 500,
top: 300,
opacity: .4,
width: 500
}, 500);
})
})
</script>
</body>
- 至關重要的一點,停止影片排隊stop
影片或者效果一旦觸發就會執行,如果多次觸發,就造成多個影片或者效果排隊執行,
? 停止影片排隊的方法為:stop() ;
- stop() 方法用于停止影片或效果,
- stop() 寫到影片或者效果的前面, 相當于停止結束上一次的影片,
? 總結: 每次使用影片之前,先呼叫 stop() ,在呼叫影片,
- 事件的切換
jQuery中為我們添加了一個新事件 hover() ; 功能類似 css 中的偽類 :hover
語法
hover([over,]out) // 其中over和out為兩個函式
- over:滑鼠移到元素上要觸發的函式(相當于mouseenter)
- out:滑鼠移出元素要觸發的函式(相當于mouseleave)
- 如果只寫一個函式,則滑鼠經過和離開都會觸發它
代碼實體:
<body>
<ul >
<li>
<a href="https://www.cnblogs.com/BM-laoli/p/#">微博</a>
<ul><li><a href="">私信</a></li><li><a href="">評論</a></li><li><a href="">@我</a></li></ul>
</li>
<li>
<a href="https://www.cnblogs.com/BM-laoli/p/#">微博</a>
<ul><li><a href="">私信</a></li><li><a href="">評論</a></li><li><a href="">@我</a></li></ul>
</li>
</ul>
<script>
$(function() {
// 滑鼠經過
// $(".nav>li").mouseover(function() {
// // $(this) jQuery 當前元素 this不要加引號
// // show() 顯示元素 hide() 隱藏元素
// $(this).children("ul").slideDown(200);
// });
// // 滑鼠離開
// $(".nav>li").mouseout(function() {
// $(this).children("ul").slideUp(200);
// });
// 1. 事件切換 hover 就是滑鼠經過和離開的復合寫法
// $(".nav>li").hover(function() {
// $(this).children("ul").slideDown(200);
// }, function() {
// $(this).children("ul").slideUp(200);
// });
// 2. 事件切換 hover 如果只寫一個函式,那么滑鼠經過和滑鼠離開都會觸發這個函式
$(".nav>li").hover(function() {
// stop 方法必須寫到影片的前面
$(this).children("ul").stop().slideToggle();
});
})
</script>
</body>
總結一下:jQuery 的基礎使用:

轉載請註明出處,本文鏈接:https://www.uj5u.com/qiye/141701.html
標籤:JavaScript
上一篇:演算法的理論與實踐
下一篇:DOM解讀
