日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

jQuery学习笔记系列(一)——入口函数,jQuery对象和DOM对象,jQuery选择器、样式操作、效果(显示隐藏、滑入滑出、淡入淡出、自定义动画、停止动画队列)

發(fā)布時(shí)間:2024/7/5 编程问答 25 豆豆

day01 - jQuery

學(xué)習(xí)目標(biāo):

能夠說出什么是 jQuery
能夠說出 jQuery 的優(yōu)點(diǎn)
能夠簡單使用 jQuery
能夠說出 DOM 對(duì)象和 jQuery 對(duì)象的區(qū)別
能夠?qū)懗龀S玫?jQuery 選擇器
能夠操作 jQuery 樣式
能夠?qū)懗龀S玫?jQuery 動(dòng)畫

1.1. jQuery 介紹

1.1.1 JavaScript 庫

? JavaScript庫:即 library,是一個(gè)封裝好的特定的集合(方法和函數(shù))。從封裝一大堆函數(shù)的角度理解庫,就是在這個(gè)庫中,封裝了很多預(yù)先定義好的函數(shù)在里面,比如動(dòng)畫animate、hide、show,比如獲取元素等。

簡單理解: 就是一個(gè)JS 文件,里面對(duì)我們原生js代碼進(jìn)行了封裝,存放到里面。這樣我們可以快速高效的使用這些封裝好的功能了。

比如 jQuery,就是為了快速方便的操作DOM,里面基本都是函數(shù)(方法)。

? 常見的JavaScript 庫:jQuery、Prototype、YUI、Dojo、Ext JS、移動(dòng)端的zepto等,這些庫都是對(duì)原生 JavaScript 的封裝,內(nèi)部都是用 JavaScript 實(shí)現(xiàn)的,我們主要學(xué)習(xí)的是 jQuery。

1.1.2 jQuery的概念

? jQuery總體概況如下 :

  • jQuery 是一個(gè)快速、簡潔的 JavaScript 庫,其設(shè)計(jì)的宗旨是“write Less,Do More”,即倡導(dǎo)寫更少的代碼,做更多的事情。

  • j 就是 JavaScript; Query 查詢; 意思就是查詢js,把js中的DOM操作做了封裝,我們可以快速的查詢使用里面的功能。

  • jQuery 封裝了 JavaScript 常用的功能代碼,優(yōu)化了 DOM 操作、事件處理、動(dòng)畫設(shè)計(jì)和 Ajax 交互。

  • 學(xué)習(xí)jQuery本質(zhì): 就是學(xué)習(xí)調(diào)用這些函數(shù)(方法)。

  • jQuery 出現(xiàn)的目的是加快前端人員的開發(fā)速度,我們可以非常方便的調(diào)用和使用它,從而提高開發(fā)效率。

1.1.3 jQuery的優(yōu)點(diǎn)

  • 輕量級(jí)。核心文件才幾十kb,不會(huì)影響頁面加載速度。
  • 跨瀏覽器兼容,基本兼容了現(xiàn)在主流的瀏覽器。
  • 鏈?zhǔn)骄幊獭㈦[式迭代。
  • 對(duì)事件、樣式、動(dòng)畫支持,大大簡化了DOM操作。
  • 支持插件擴(kuò)展開發(fā)。有著豐富的第三方的插件,例如:樹形菜單、日期控件、輪播圖等。
  • 免費(fèi)、開源。
  • 1.2. jQuery 的基本使用

    1.2.1 jQuery 的下載

    ? jQuery的官網(wǎng)地址: https://jquery.com/,官網(wǎng)即可下載最新版本。

    各個(gè)版本的下載:https://code.jquery.com/

    ? 版本介紹:

    1x :兼容 IE 678 等低版本瀏覽器, 官網(wǎng)不再更新

    2x :不兼容 IE 678 等低版本瀏覽器, 官網(wǎng)不再更新

    3x :不兼容 IE 678 等低版本瀏覽器, 是官方主要更新維護(hù)的版本

    1.2.2. 體驗(yàn)jQuery

    ? 步驟:

    • 引入jQuery文件。
    • 在文檔最末尾插入 script 標(biāo)簽,書寫體驗(yàn)代碼。
    • $(‘div’).hide() 可以隱藏盒子。

    1.2.3. jQuery的入口函數(shù)

    ? jQuery中常見的兩種入口函數(shù):

    // 第一種: 簡單易用。 $(function () { ... // 此處是頁面 DOM 加載完成的入口 }) ; // 第二種: 繁瑣,但是也可以實(shí)現(xiàn) $(document).ready(function(){... // 此處是頁面DOM加載完成的入口 });

    ? 總結(jié):

  • 等著 DOM 結(jié)構(gòu)渲染完畢即可執(zhí)行內(nèi)部代碼,不必等到所有外部資源加載完成,jQuery 幫我們完成了封裝。
  • 相當(dāng)于原生 js 中的 DOMContentLoaded
  • 不同于原生 js 中的 load 事件是等頁面文檔、外部的 js 文件、css文件、圖片加載完畢才執(zhí)行內(nèi)部代碼。
  • 更推薦使用第一種方式。
  • 1.2.4. jQuery中的頂級(jí)對(duì)象$

  • $是 jQuery 的別稱,在代碼中可以使用 jQuery 代替,但一般為了方便,通常都直接使用 $ 。
  • $是jQuery的頂級(jí)對(duì)象,相當(dāng)于原生JavaScript中的 window把元素利用$包裝成jQuery對(duì)象,就可以調(diào)用jQuery 的方法。
  • <!DOCTYPE html> <html lang="en"><head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><meta http-equiv="X-UA-Compatible" content="ie=edge"><title>Document</title><script src="jquery.min.js"></script><style>div {width: 200px;height: 200px;background-color: pink;}</style> </head><body><div></div><script>// 1. $ 是jQuery的別稱(另外的名字)// $(function() {// alert(11)// });jQuery(function() {// alert(11)// $('div').hide();jQuery('div').hide();});// 2. $同時(shí)也是jQuery的 頂級(jí)對(duì)象</script> </body></html>

    1.2.5. jQuery 對(duì)象和 DOM 對(duì)象

    ? 使用 jQuery 方法和原生JS獲取的元素是不一樣的,總結(jié)如下 :

  • 用原生 JS 獲取來的對(duì)象就是 DOM 對(duì)象
  • jQuery 方法獲取的元素就是 jQuery 對(duì)象。
  • jQuery 對(duì)象本質(zhì)是: 利用$對(duì)DOM 對(duì)象包裝后產(chǎn)生的對(duì)象(偽數(shù)組形式存儲(chǔ))。
  • 注意:

    只有 jQuery 對(duì)象才能使用 jQuery 方法,DOM 對(duì)象則使用原生的 JavaScirpt 方法。

    <!DOCTYPE html> <html lang="en"><head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><meta http-equiv="X-UA-Compatible" content="ie=edge"><title>Document</title><script src="jquery.min.js"></script><style>div {width: 100px;height: 100px;background-color: pink;}</style> </head><body><div></div><span></span><script>// 1. DOM 對(duì)象: 用原生js獲取過來的對(duì)象就是DOM對(duì)象var myDiv = document.querySelector('div'); // myDiv 是DOM對(duì)象var mySpan = document.querySelector('span'); // mySpan 是DOM對(duì)象console.dir(myDiv);// 2. jQuery對(duì)象: 用jquery方式獲取過來的對(duì)象是jQuery對(duì)象。 本質(zhì):通過$把DOM元素進(jìn)行了包裝$('div'); // $('div')是一個(gè)jQuery 對(duì)象$('span'); // $('span')是一個(gè)jQuery 對(duì)象console.dir($('div'));// 3. jQuery 對(duì)象只能使用 jQuery 方法,DOM 對(duì)象則使用原生的 JavaScirpt 屬性和方法// myDiv.style.display = 'none';// myDiv.hide(); myDiv是一個(gè)dom對(duì)象不能使用 jquery里面的hide方法// $('div').style.display = 'none'; 這個(gè)$('div')是一個(gè)jQuery對(duì)象不能使用原生js 的屬性和方法</script> </body></html>

    1.2.6. jQuery 對(duì)象和 DOM 對(duì)象轉(zhuǎn)換

    ? DOM 對(duì)象與 jQuery 對(duì)象之間是可以相互轉(zhuǎn)換的。因?yàn)樵鷍s 比 jQuery 更大,原生的一些屬性和方法 jQuery沒有給我們封裝. 要想使用這些屬性和方法需要把jQuery對(duì)象轉(zhuǎn)換為DOM對(duì)象才能使用。

    // 1.DOM對(duì)象轉(zhuǎn)換成jQuery對(duì)象,方法只有一種 var box = document.getElementById('box'); // 獲取DOM對(duì)象 var jQueryObject = $(box); // 把DOM對(duì)象轉(zhuǎn)換為 jQuery 對(duì)象// 2.jQuery 對(duì)象轉(zhuǎn)換為 DOM 對(duì)象有兩種方法: // 2.1 jQuery對(duì)象[索引值] var domObject1 = $('div')[0]// 2.2 jQuery對(duì)象.get(索引值) var domObject2 = $('div').get(0) <!DOCTYPE html> <html lang="en"><head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><meta http-equiv="X-UA-Compatible" content="ie=edge"><title>Document</title><script src="jquery.min.js"></script> </head><body><video src="mov.mp4" muted></video><script>// 1. DOM對(duì)象轉(zhuǎn)換為 jQuery對(duì)象// (1) 我們直接獲取視頻,得到就是jQuery對(duì)象// $('video');// (2) 我們已經(jīng)使用原生js 獲取過來 DOM對(duì)象var myvideo = document.querySelector('video');// $(myvideo).play(); jquery里面沒有play 這個(gè)方法// 2. jQuery對(duì)象轉(zhuǎn)換為DOM對(duì)象// myvideo.play();$('video')[0].play()$('video').get(0).play()</script> </body></html>

    總結(jié):實(shí)際開發(fā)比較常用的是把DOM對(duì)象轉(zhuǎn)換為jQuery對(duì)象,這樣能夠調(diào)用功能更加強(qiáng)大的jQuery中的方法。

    1.3. jQuery 選擇器

    ? 原生 JS 獲取元素方式很多,很雜,而且兼容性情況不一致,因此 jQuery 給我們做了封裝,使獲取元素統(tǒng)一標(biāo)準(zhǔn)。

    1.3.1. 基礎(chǔ)選擇器

    $("選擇器") // 里面選擇器直接寫 CSS 選擇器即可,但是要加引號(hào)


    ?

    1.3.2. 層級(jí)選擇器

    ? 層級(jí)選擇器最常用的兩個(gè)分別為:后代選擇器和子代選擇器。

    ?

    基礎(chǔ)選擇器和層級(jí)選擇器案例代碼

    <body><div>我是div</div><div class="nav">我是nav div</div><p>我是p</p><ul><li>我是ul 的</li><li>我是ul 的</li> <li>我是ul 的</li></ul><script>$(function() {console.log($(".nav"));console.log($("ul li"));})</script> </body>

    1.3.3. 篩選選擇器

    ? 篩選選擇器,顧名思義就是在所有的選項(xiàng)中選擇滿足條件的進(jìn)行篩選選擇。常見如下 :

    案例代碼

    <body><ul><li>多個(gè)里面篩選幾個(gè)</li><li>多個(gè)里面篩選幾個(gè)</li><li>多個(gè)里面篩選幾個(gè)</li><li>多個(gè)里面篩選幾個(gè)</li><li>多個(gè)里面篩選幾個(gè)</li><li>多個(gè)里面篩選幾個(gè)</li></ul><ol><li>多個(gè)里面篩選幾個(gè)</li><li>多個(gè)里面篩選幾個(gè)</li><li>多個(gè)里面篩選幾個(gè)</li><li>多個(gè)里面篩選幾個(gè)</li><li>多個(gè)里面篩選幾個(gè)</li><li>多個(gè)里面篩選幾個(gè)</li></ol><script>$(function() {$("ul li:first").css("color", "red");$("ul li:eq(2)").css("color", "blue");$("ol li:odd").css("color", "skyblue");$("ol li:even").css("color", "pink");})</script> </body>

    另: jQuery中還有一些篩選方法,類似DOM中的通過一個(gè)節(jié)點(diǎn)找另外一個(gè)節(jié)點(diǎn),父、子、兄以外有所加強(qiáng)。

    <!DOCTYPE html> <html lang="en"><head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><meta http-equiv="X-UA-Compatible" content="ie=edge"><title>Document</title><script src="jquery.min.js"></script> </head><body><ol><li>我是ol 的li</li><li>我是ol 的li</li><li class="item">我是ol 的li</li><li>我是ol 的li</li><li>我是ol 的li</li><li>我是ol 的li</li></ol><ul><li>我是ol 的li</li><li>我是ol 的li</li><li>我是ol 的li</li><li>我是ol 的li</li><li>我是ol 的li</li><li>我是ol 的li</li></ul><div class="current">俺有current</div><div>俺木有current</div><script>// 注意一下都是方法 帶括號(hào)$(function() {// 1. 兄弟元素siblings 除了自身元素之外的所有親兄弟$("ol .item").siblings("li").css("color", "red");// 2. 第n個(gè)元素var index = 2;// (1) 我們可以利用選擇器的方式選擇// $("ul li:eq(2)").css("color", "blue");// $("ul li:eq("+index+")").css("color", "blue");// (2) 我們可以利用選擇方法的方式選擇 更推薦這種寫法// $("ul li").eq(2).css("color", "blue");// $("ul li").eq(index).css("color", "blue");// 3. 判斷是否有某個(gè)類名console.log($("div:first").hasClass("current"));console.log($("div:last").hasClass("current"));});</script> </body></html>


    偏重于記憶,演示代碼略。
    案例:新浪下拉菜單:

    <!DOCTYPE html> <html><head><meta charset="utf-8"><title>新浪下拉菜單</title><style type="text/css">* {margin: 0;padding: 0;box-sizing: border-box;}li {list-style: none;}a {text-decoration: none;}.nav {width: 402px;height: 50px;border: 1px solid #ccc;margin: 200px auto;} .nav>li {float: left;width: 100px;height: 50px;text-align: center;}.nav>li:hover {background-color: #FFC0CB;}.nav>li a {display: block;height: 50px;line-height: 50px;}.dropdown {display: none;}.dropdown>li {width: 100px;height: 50px;line-height: 50px;border: 1px solid #FFC0CB;border-top: 0;}</style><script src="./js/jquery-3.5.0.js"></script></head><body><ul class="nav"><li><a href="#">微博</a><ul class="dropdown"><li><a href="">私信</a></li><li><a href="">評(píng)論</a></li><li><a href="">@我</a></li></ul></li><li><a href="#">微博</a><ul class="dropdown"><li><a href="">私信</a></li><li><a href="">評(píng)論</a></li><li><a href="">@我</a></li></ul></li><li><a href="#">微博</a><ul class="dropdown"><li><a href="">私信</a></li><li><a href="">評(píng)論</a></li><li><a href="">@我</a></li></ul></li><li><a href="#">微博</a><ul class="dropdown"><li><a href="">私信</a></li><li><a href="">評(píng)論</a></li><li><a href="">@我</a></li></ul></li> </ul><script type="text/javascript">$(function() {// 鼠標(biāo)經(jīng)過$(".nav>li").mouseover(function() {$(this).children("ul").show();})// 鼠標(biāo)離開$(".nav>li").mouseout(function() {$(this).children("ul").hide();})})</script></body> </html>

    1.3.4 知識(shí)鋪墊

    • jQuery 設(shè)置樣式
    $('div').css('屬性', '值')
    • jQuery 里面的排他思想
    // 想要多選一的效果,排他思想:當(dāng)前元素設(shè)置樣式,其余的兄弟元素清除樣式。 $(this).css(“color”,”red”); $(this).siblings(). css(“color”,””);
    • 隱式迭代
    // 遍歷內(nèi)部 DOM 元素(偽數(shù)組形式存儲(chǔ))的過程就叫做隱式迭代。 // 簡單理解:給匹配到的所有元素進(jìn)行循環(huán)遍歷,執(zhí)行相應(yīng)的方法,而不用我們再進(jìn)行循環(huán),簡化我們的操作,方便我們調(diào)用。 $('div').hide(); // 頁面中所有的div全部隱藏,不用循環(huán)操作
    • 鏈?zhǔn)骄幊?/li>
    // 鏈?zhǔn)骄幊淌菫榱斯?jié)省代碼量,看起來更優(yōu)雅。 $(this).css('color', 'red').sibling().css('color', '');

    1.3.5 案例:淘寶服飾精品案例

    思路分析:
    1.核心原理:鼠標(biāo)經(jīng)過左側(cè)盒子某個(gè)小li,就讓內(nèi)容區(qū)盒子相對(duì)應(yīng)圖片顯示,其余的圖片隱藏。
    2.需要得到當(dāng)前小li 的索引號(hào),就可以顯示對(duì)應(yīng)索引號(hào)的圖片
    3.jQuery 得到當(dāng)前元素索引號(hào) $(this).index()
    4.中間對(duì)應(yīng)的圖片,可以通過 eq(index) 方法去選擇
    5.顯示元素 show() 隱藏元素 hide()

    ? 代碼實(shí)現(xiàn):

    <!DOCTYPE html> <html><head><meta charset="utf-8"><title>淘寶精品服飾案例</title><script src="./js/jquery-3.5.0.js"></script><style type="text/css">* {margin: 0;padding: 0;box-sizing: border-box;}li {list-style: none;}a {text-decoration: none;}#box {width: 302px;height: 272px;border: 1px solid pink;margin: 200px auto;}.left {float: left;width: 100px;}.left li {width: 100%;height: 30px;line-height: 30px;text-align: center;border-bottom: 1px solid pink;border-right: 1px solid pink;}.left li:hover {background-color: pink;}.left li:last-child {border-bottom: 0;}#content {float: left;width: 200px;height: 272px;/* overflow: hidden; */}#content div {width: 200px;height: 272px;display: none;}#content .current {display: block;}#content div a img{width: 200px;height: 272px;}</style></head><body><div id="box"><ul class="left"><li><a href="">女靴</a></li><li><a href="">雪地靴</a></li><li><a href="">冬裙</a></li><li><a href="">呢大衣</a></li><li><a href="">毛衣</a></li><li><a href="">棉服</a></li><li><a href="">女褲</a></li><li><a href="">羽絨服</a></li><li><a href="">牛仔褲</a></li></ul><div id="content"><div class="current"><a href="#"><img src="./img/女靴.jpg" alt=""></a></div><div><a href="#"><img src="./img/雪地靴.jpg" alt=""></a></div><div><a href="#"><img src="./img/冬裙.jpg" alt=""></a></div><div><a href="#"><img src="./img/呢大衣.jpg" alt=""></a></div><div><a href="#"><img src="./img/毛衣.jpg" alt=""></a></div><div><a href="#"><img src="./img/棉服.jpg" alt=""></a></div><div><a href="#"><img src="./img/女褲.jpg" alt=""></a></div><div><a href="#"><img src="./img/羽絨服.jpg" alt=""></a></div><div><a href="#"><img src="./img/牛仔褲.jpg" alt=""></a></div></div></div><script type="text/javascript">$(function() {// 1、鼠標(biāo)經(jīng)過左側(cè)的li時(shí)$("#box>ul li").mouseover(function() {//2、得到當(dāng)前l(fā)i的索引號(hào)var index = $(this).index();//3、讓我們右側(cè)的div盒子相應(yīng)的索引號(hào)的圖片顯示出來就好了// $("#box #content>div").eq(index).show()//4、讓其余的圖片(就是其他的兄弟)隱藏起來:排他思想// $("#box #content>div").eq(index).siblings("div").hide()// 將上面的3 4 合二為一:鏈?zhǔn)骄幊?/span>$("#box #content>div").eq(index).show().siblings("div").hide();})})</script></body> </html>

    1.4. jQuery 樣式操作

    ? jQuery中常用的樣式操作有兩種:css() 和 設(shè)置類樣式方法

    1.4.1. 方法1: 操作 css 方法

    ? jQuery 可以使用 css 方法來修改簡單元素樣式; 也可以操作類,修改多個(gè)樣式。

    ? 常用以下三種形式 :

    // 1.參數(shù)只寫屬性名,則是返回屬性值 var strColor = $(this).css('color');// 2. 參數(shù)是屬性名,屬性值,逗號(hào)分隔,是設(shè)置一組樣式,屬性必須加引號(hào),值如果是數(shù)字可以不用跟單位和引號(hào) $(this).css(''color'', ''red'');// 3. 參數(shù)可以是對(duì)象形式,方便設(shè)置多組樣式。屬性名和屬性值用冒號(hào)隔開, 屬性可以不用加引號(hào) $(this).css({ "color":"white","font-size":"20px"}); //如果是復(fù)合屬性則必須采取駝峰命名法,如果值不是數(shù)字,則需要加引號(hào)

    ? 注意:
    1)css() 多用于樣式少時(shí)操作,多了則不太方便。
    2)如果是復(fù)合屬性則必須采取駝峰命名法,如果值不是數(shù)字,則需要加引號(hào)

    1.4.2. 方法2: 設(shè)置類樣式方法

    ? 作用等同于以前的 classList,可以操作類樣式, 注意操作類里面的參數(shù)不要加點(diǎn)。

    ? 常用的三種設(shè)置類樣式方法:

    // 1.添加類 $("div").addClass("current");// 2.刪除類 $("div").removeClass("current");// 3.切換類:如果已經(jīng)存在current類,則去除該類;如果不存在current類,則加上該類 $("div").toggleClass("current");

    ? 注意:

  • 設(shè)置類樣式方法比較適合樣式多時(shí)操作,可以彌補(bǔ)css()的不足。
  • 原生 JS 中 className 會(huì)覆蓋元素原先里面的類名,jQuery 里面類操作只是對(duì)指定類進(jìn)行操作,不影響原先的類名,相當(dāng)于追加一個(gè)類名!。
  • 1.4.3. 案例:tab 欄切換

    思路分析:
    1.點(diǎn)擊上部的li,當(dāng)前l(fā)i 添加current類,其余兄弟移除類。
    2.點(diǎn)擊的同時(shí),得到當(dāng)前l(fā)i 的索引號(hào)
    3.讓下部里面相應(yīng)索引號(hào)的item顯示,其余的item隱藏

    ? 代碼實(shí)現(xiàn):

    <!DOCTYPE html> <html lang="en"><head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><meta http-equiv="X-UA-Compatible" content="ie=edge"><title>Document</title><style>* {margin: 0;padding: 0;}li {list-style-type: none;}.tab {width: 978px;margin: 100px auto;}.tab_list {height: 39px;border: 1px solid #ccc;background-color: #f1f1f1;}.tab_list li {float: left;height: 39px;line-height: 39px;padding: 0 20px;text-align: center;cursor: pointer;}.tab_list .current {background-color: #c81623;color: #fff;}.item_info {padding: 20px 0 0 20px;}.item {display: none;}</style><script src="jquery.min.js"></script> </head><body><div class="tab"><div class="tab_list"><ul><li class="current">商品介紹</li><li>規(guī)格與包裝</li><li>售后保障</li><li>商品評(píng)價(jià)(50000)</li><li>手機(jī)社區(qū)</li></ul></div><div class="tab_con"><div class="item" style="display: block;">商品介紹模塊內(nèi)容</div><div class="item">規(guī)格與包裝模塊內(nèi)容</div><div class="item">售后保障模塊內(nèi)容</div><div class="item">商品評(píng)價(jià)(50000)模塊內(nèi)容</div><div class="item">手機(jī)社區(qū)模塊內(nèi)容</div></div></div><script>$(function() {// 1.點(diǎn)擊上部的li,當(dāng)前l(fā)i 添加current類,其余兄弟移除類$(".tab_list li").click(function() {// 鏈?zhǔn)骄幊滩僮?/span>$(this).addClass("current").siblings().removeClass("current");// 2.點(diǎn)擊的同時(shí),得到當(dāng)前l(fā)i 的索引號(hào)var index = $(this).index();console.log(index);// 3.讓下部里面相應(yīng)索引號(hào)的item顯示,其余的item隱藏$(".tab_con .item").eq(index).show().siblings().hide();});})</script> </body></html>

    1.5. jQuery 效果


    ? jQuery 給我們封裝了很多動(dòng)畫效果,最為常見的如下:

    • 顯示隱藏:show() / hide() / toggle() ;
    • 劃入畫出:slideDown() / slideUp() / slideToggle() ;
    • 淡入淡出:fadeIn() / fadeOut() / fadeToggle() / fadeTo() ;
    • 自定義動(dòng)畫:animate() ;

    注意:

    動(dòng)畫或者效果一旦觸發(fā)就會(huì)執(zhí)行,如果多次觸發(fā),就造成多個(gè)動(dòng)畫或者效果排隊(duì)執(zhí)行。

    jQuery為我們提供另一個(gè)方法,可以停止動(dòng)畫排隊(duì):stop() ;

    1.5.1. 顯示隱藏

    ? 顯示隱藏動(dòng)畫,常見有三個(gè)方法:show() / hide() / toggle() ;

    ? 語法規(guī)范如下:

    代碼演示

    <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);})// 一般情況下,我們都不加參數(shù)直接顯示隱藏就可以了});</script> </body>

    1.5.2. 滑入滑出

    ? 滑入滑出動(dòng)畫,常見有三個(gè)方法:slideDown() / slideUp() / slideToggle() ;

    ? 語法規(guī)范如下:

    代碼演示

    <body><button>下拉滑動(dòng)</button><button>上拉滑動(dòng)</button><button>切換滑動(dòng)</button><div></div><script>$(function() {$("button").eq(0).click(function() {// 下滑動(dòng) slideDown()$("div").slideDown();})$("button").eq(1).click(function() {// 上滑動(dòng) slideUp()$("div").slideUp(500);})$("button").eq(2).click(function() {// 滑動(dòng)切換 slideToggle()$("div").slideToggle(500);});});</script> </body>

    1.5.3 淡入淡出

    ? 淡入淡出動(dòng)畫,常見有四個(gè)方法:fadeIn() / fadeOut() / fadeToggle() / fadeTo() ;

    ? 語法規(guī)范如下:



    代碼演示

    <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() 這個(gè)速度和透明度要必須寫$("div").fadeTo(1000, 0.5);});});</script> </body>

    案例:高亮顯示

    代碼演示:

    <!DOCTYPE html> <html><head lang="en"><meta charset="UTF-8"><title></title><style type="text/css">* {margin: 0;padding: 0;}ul {list-style: none;}body {background: #000;}.wrap {margin: 100px auto 0;width: 630px;height: 394px;padding: 10px 0 0 10px;background: #000;overflow: hidden;border: 1px solid #fff;}.wrap li {float: left;margin: 0 10px 10px 0;}.wrap img {display: block;border: 0;}</style><script src="jquery.min.js"></script><script>$(function() {//鼠標(biāo)進(jìn)入的時(shí)候,其他的li標(biāo)簽透明度:0.5$(".wrap li").hover(function() {$(this).siblings().stop().fadeTo(400, 0.5);}, function() {// 鼠標(biāo)離開,其他li 透明度改為 1$(this).siblings().stop().fadeTo(400, 1);})});</script> </head><body><div class="wrap"><ul><li><a href="#"><img src="images/01.jpg" alt="" /></a></li><li><a href="#"><img src="images/02.jpg" alt="" /></a></li><li><a href="#"><img src="images/03.jpg" alt="" /></a></li><li><a href="#"><img src="images/04.jpg" alt="" /></a></li><li><a href="#"><img src="images/05.jpg" alt="" /></a></li><li><a href="#"><img src="images/06.jpg" alt="" /></a></li></ul></div> </body></html>

    1.5.4 自定義動(dòng)畫

    ? 自定義動(dòng)畫非常強(qiáng)大,通過參數(shù)的傳遞可以模擬以上所有動(dòng)畫,方法為:animate() ;

    ? 語法規(guī)范如下:

    代碼演示

    <body><button>動(dòng)起來</button><div></div><script>$(function() {$("button").click(function() {$("div").animate({left: 500,top: 300,opacity: .4,width: 500}, 500);})})</script> </body>

    1.5.5 停止動(dòng)畫排隊(duì)

    ? 動(dòng)畫或者效果一旦觸發(fā)就會(huì)執(zhí)行,如果多次觸發(fā),就造成多個(gè)動(dòng)畫或者效果排隊(duì)執(zhí)行。

    ? 停止動(dòng)畫排隊(duì)的方法為:stop() ;

    • stop() 方法用于停止動(dòng)畫或效果。
    • stop() 寫到動(dòng)畫或者效果的前面相當(dāng)于停止結(jié)束上一次的動(dòng)畫。

    ? 總結(jié): 每次使用動(dòng)畫之前,先調(diào)用 stop() ,在調(diào)用動(dòng)畫。

    1.5.6. 事件切換

    ? jQuery中為我們添加了一個(gè)新事件 hover() ; 功能類似 css 中的偽類 :hover 。介紹如下

    語法

    hover([over,]out) // 其中over和out為兩個(gè)函數(shù)
    • over:鼠標(biāo)移到元素上要觸發(fā)的函數(shù)(相當(dāng)于mouseenter)
    • out:鼠標(biāo)移出元素要觸發(fā)的函數(shù)(相當(dāng)于mouseleave)
    • 如果只寫一個(gè)函數(shù),則鼠標(biāo)經(jīng)過和離開都會(huì)觸發(fā)它

    hover事件和停止動(dòng)畫排列案例(新浪下拉菜單案例優(yōu)化)

    <!DOCTYPE html> <html><head><meta charset="utf-8"><title>新浪下拉菜單</title><style type="text/css">* {margin: 0;padding: 0;box-sizing: border-box;}li {list-style: none;}a {text-decoration: none;}.nav {width: 402px;height: 50px;border: 1px solid #ccc;margin: 200px auto;}.nav>li {float: left;width: 100px;height: 50px;text-align: center;}.nav>li:hover {background-color: #FFC0CB;}.nav>li a {display: block;height: 50px;line-height: 50px;}.dropdown {display: none;}.dropdown>li {width: 100px;height: 50px;line-height: 50px;border: 1px solid #FFC0CB;border-top: 0;}</style><script src="./js/jquery-3.5.0.js"></script></head><body><ul class="nav"><li><a href="#">微博</a><ul class="dropdown"><li><a href="">私信</a></li><li><a href="">評(píng)論</a></li><li><a href="">@我</a></li></ul></li><li><a href="#">微博</a><ul class="dropdown"><li><a href="">私信</a></li><li><a href="">評(píng)論</a></li><li><a href="">@我</a></li></ul></li><li><a href="#">微博</a><ul class="dropdown"><li><a href="">私信</a></li><li><a href="">評(píng)論</a></li><li><a href="">@我</a></li></ul></li><li><a href="#">微博</a><ul class="dropdown"><li><a href="">私信</a></li><li><a href="">評(píng)論</a></li><li><a href="">@我</a></li></ul></li></ul><script type="text/javascript">$(function() {// // 鼠標(biāo)經(jīng)過// $(".nav>li").mouseover(function() {// // $(this).children("ul").show();// $(this).children("ul").stop().slideDown(300);// })// // 鼠標(biāo)離開// $(".nav>li").mouseout(function() {// // $(this).children("ul").hide();// $(this).children("ul").stop().slideUp(300);// })// 1.事件切換 hover :就是鼠標(biāo)經(jīng)過和離開的復(fù)合寫法// $(".nav>li").hover(function() {// $(this).children("ul").stop().slideDown(300);// },function() {// $(this).children("ul").stop().slideUp(300);// })// 2.事件切換 hover 如果只寫一個(gè)函數(shù),那么鼠標(biāo)經(jīng)過和離開都會(huì)觸發(fā)這個(gè)函數(shù)$(".nav>li").hover(function() {// stop 方法必須寫到動(dòng)畫的前面$(this).children("ul").stop().slideToggle();})})</script></body> </html>

    1.5.7. 案例:王者榮耀手風(fēng)琴效果

    思路分析:
    1.鼠標(biāo)經(jīng)過某個(gè)小li 有兩步操作:
    2.當(dāng)前小li 寬度變?yōu)?224px, 同時(shí)里面的小圖片淡出,大圖片淡入
    3.其余兄弟小li寬度變?yōu)?9px, 小圖片淡入, 大圖片淡出

    ? 代碼實(shí)現(xiàn):

    <!doctype html> <html><head><meta charset="utf-8"><title>手風(fēng)琴案例</title><style type="text/css">* {margin: 0;padding: 0;}img {display: block;}ul {list-style: none;}.king {width: 852px;margin: 100px auto;background: url(images/bg.png) no-repeat;overflow: hidden;padding: 10px;}.king ul {overflow: hidden;}.king li {position: relative;float: left;width: 69px;height: 69px;margin-right: 10px;}.king li.current {width: 224px;}.king li.current .big {display: block;}.king li.current .small {display: none;}.big {width: 224px;display: none;}.small {position: absolute;top: 0;left: 0;width: 69px;height: 69px;border-radius: 5px;}</style></head><body><script src="js/jquery.min.js"></script><script type="text/javascript">$(function() {// 鼠標(biāo)經(jīng)過某個(gè)小li 有兩步操作:$(".king li").mouseenter(function() {// 1.當(dāng)前小li 寬度變?yōu)?224px, 同時(shí)里面的小圖片淡出,大圖片淡入$(this).stop().animate({width: 224}).find(".small").stop().fadeOut().siblings(".big").stop().fadeIn();// 2.其余兄弟小li寬度變?yōu)?9px, 小圖片淡入, 大圖片淡出$(this).siblings("li").stop().animate({width: 69}).find(".small").stop().fadeIn().siblings(".big").stop().fadeOut();})});</script><div class="king"><ul><li class="current"><a href="#"><img src="images/m1.jpg" alt="" class="small"><img src="images/m.png" alt="" class="big"></a></li><li><a href="#"><img src="images/l1.jpg" alt="" class="small"><img src="images/l.png" alt="" class="big"></a></li><li><a href="#"><img src="images/c1.jpg" alt="" class="small"><img src="images/c.png" alt="" class="big"></a></li><li><a href="#"><img src="images/w1.jpg" alt="" class="small"><img src="images/w.png" alt="" class="big"></a></li><li><a href="#"><img src="images/z1.jpg" alt="" class="small"><img src="images/z.png" alt="" class="big"></a></li><li><a href="#"><img src="images/h1.jpg" alt="" class="small"><img src="images/h.png" alt="" class="big"></a></li><li><a href="#"><img src="images/t1.jpg" alt="" class="small"><img src="images/t.png" alt="" class="big"></a></li></ul></div> </body></html>

    1.6. 今日總結(jié)

    總結(jié)

    以上是生活随笔為你收集整理的jQuery学习笔记系列(一)——入口函数,jQuery对象和DOM对象,jQuery选择器、样式操作、效果(显示隐藏、滑入滑出、淡入淡出、自定义动画、停止动画队列)的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。