App下載

jQuery的高級(jí)教程:動(dòng)畫、遍歷和事件綁定實(shí)例

猿友 2021-01-11 10:51:52 瀏覽數(shù) (1965)
反饋

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

  • 學(xué)會(huì)如何使用jQuery的動(dòng)畫效果
  • 學(xué)會(huì)如何進(jìn)行遍歷和事件綁定
  • 熟練應(yīng)用jQuery進(jìn)行相關(guān)復(fù)雜操作

學(xué)習(xí)內(nèi)容:

一、jQuery高級(jí)

1、動(dòng)畫:三種方式顯示和隱藏元素
  • 默認(rèn)顯示和隱藏元素show([speed,[easing],[fn]])hide([speed,[easing],[fn]])toggle([speed,[easing],[fn]])
  • 滾動(dòng)顯示和隱藏元素slideDown([speed,[easing],[fn]])slideUp([speed,[easing],[fn]])slideToggle([speed,[easing],[fn]])
  • 淡入淡出顯示和隱藏元素fadeIn([speed,[easing],[fn]])fadeOut([speed,[easing],[fn]])fadeToggle([speed,[easing],[fn]])
  • 參數(shù)speed:速度,三種預(yù)定義的值(“slow”,“normal”,“fast”)或表示動(dòng)畫時(shí)長(zhǎng)的毫秒數(shù)值(如:1000)easing:用來(lái)指定切換效果,默認(rèn)是"swing",可用參數(shù)"linear"swing:動(dòng)畫執(zhí)行時(shí)效果是“先慢,中間快,又慢”linear:動(dòng)畫執(zhí)行時(shí)的速度是勻速的fn:在動(dòng)畫完成時(shí)執(zhí)行的函數(shù),每個(gè)元素執(zhí)行一次
2、遍歷
  • js遍歷方式for(初始化值;循環(huán)結(jié)束條件;步長(zhǎng))
  • jq遍歷方式j(luò)q對(duì)象.each(callback)$.each(object,[callback])for…of jQuery3.0之后提供的版本
3、事件綁定
  • jQuery標(biāo)準(zhǔn)的綁定方式j(luò)q對(duì)象.事件方法(回調(diào)函數(shù));如果調(diào)用事件方法,不傳遞回調(diào)函數(shù),則觸發(fā)瀏覽器默認(rèn)行為表單對(duì)象.submit(); // 讓表單提交
  • on綁定事件/off解綁事件jq對(duì)象.on(事件,回調(diào)函數(shù));jq對(duì)象.off(事件); 如果不傳遞事件名稱,則解綁所有的事件
  • 事件切換:togglejq對(duì)象.toggle(fn1,fn2…); 多次點(diǎn)擊依次執(zhí)行傳遞的函數(shù)
4、案例
  • 廣告顯示和隱藏需求當(dāng)頁(yè)面加載完成后,3秒后,自動(dòng)顯示廣告廣告顯示5秒后,自動(dòng)消失分析使用定時(shí)器來(lái)完成 setTimeOut()執(zhí)行一次的定時(shí)器jQuery的顯示和隱藏的動(dòng)畫效果其實(shí)就是控制display屬性使用show/hide相關(guān)方法完成廣告的顯示
  • 抽象需求點(diǎn)擊開始,小相框快速切換點(diǎn)擊停止,小相框停止切換分析給開始按鈕綁定單擊事件定義循環(huán)定時(shí)器切換小相框的src屬性定義數(shù)組,存放圖片資源路徑生成隨機(jī)數(shù),數(shù)組索引給結(jié)束按鈕綁定單擊事件停止定時(shí)器給大相框設(shè)置src屬性
5、插件:增強(qiáng)jQuery功能
  • 實(shí)現(xiàn)方式$.fn.extend(object);增強(qiáng)通過jQuery獲取對(duì)象的功能 $("#id")$.extend(object);增強(qiáng)jQuery對(duì)象自身的功能 $/jQuery

學(xué)習(xí)產(chǎn)出:

1、 動(dòng)畫
<!DOCTYPE html>
<html>
<head>
   <meta charset="UTF-8">
   <title>Insert title here</title>
   <script type="text/javascript" src="../js/jquery-3.3.1.min.js"></script>
   <script>
       // 隱藏div
       function hideFn() {
           /*$("#showDiv").hide("slow","swing",function () {
              // alert("隱藏了。。。");
          })*/
           // 默認(rèn)方式
           // $("#showDiv").hide("slow","swing");
           // 滑動(dòng)方式
           // $("#showDiv").slideDown("slow","swing");
           // 淡入淡出方式
           $("#showDiv").fadeOut("slow","swing");
      }
?
       // 顯示div
       function showFn() {
           /*$("#showDiv").show("slow","linear",function () {
              // alert("顯示了。。。");
          })*/
           // 默認(rèn)方式
           // $("#showDiv").show("slow","swing");
           // 滑動(dòng)方式
           // $("#showDiv").slideUp("slow","swing");
           // 淡入淡出方式
           $("#showDiv").fadeIn("slow","swing");
      }
?
       // 切換顯示隱藏div
       function toggleFn() {
           /*$("#showDiv").toggle("slow","swing",function () {
              // alert("切換顯示隱藏了。。。");
          })*/
           // 默認(rèn)方式
           // $("#showDiv").toggle("slow","swing");
           // 滑動(dòng)方式
           // $("#showDiv").slideToggle("slow","swing");
           // 淡入淡出方式
           $("#showDiv").fadeToggle("slow","swing");
      }
   </script>
</head>
<body>
<input type="button" value="點(diǎn)擊按鈕隱藏div" onclick="hideFn()">
<input type="button" value="點(diǎn)擊按鈕顯示div" onclick="showFn()">
<input type="button" value="點(diǎn)擊按鈕切換div顯示和隱藏" onclick="toggleFn()">
?
<div id="showDiv" style="width:300px;height:300px;background:pink">
  div顯示和隱藏
</div>
</body>
</html>
2、遍歷
<!DOCTYPE html>
<html>
<head>
   <meta charset="UTF-8">
   <title></title>
   <script src="../js/jquery-3.3.1.min.js" type="text/javascript" charset="utf-8"></script>
   <script type="text/javascript">
?
       $(function () {
           // 獲取所有ul下面的li
           var citys = $("#city li");
           // 遍歷li
           // js遍歷方式
           for (var i = 0;i < citys.length; i++){
               // 獲取內(nèi)容
               alert(i+":"+citys[i].innerHTML);
          }
?
           // jq遍歷方式
           citys.each(function (index,element) {
               // 獲取li對(duì)象,直接用this
               // alert(this.innerHTML);
               // alert($(this).html());
               // 獲取li對(duì)象,在回調(diào)函數(shù)中定義參數(shù)index(索引) element(元素對(duì)象)
               // alert(index+":"+element.innerHTML);
               // alert(index+":"+$(element).html());
?
               // 判斷如果是上海,結(jié)束循環(huán)
               if ("上海"==$(this).html()){
                   // 如果當(dāng)前回調(diào)函數(shù)返回值是false,終止循環(huán)
                   // 如果當(dāng)前回調(diào)函數(shù)返回值是true,終止本次循環(huán),繼續(xù)下次循環(huán)
                   return false;
                   // return true;
              }
               alert(index+":"+$(element).html());
          });
?
           $.each(citys,function () {
               alert($(this).html());
          });
?
           for (li of citys){
               alert($(li).html());
          }
?
      });
?
   </script>
</head>
<body>
<ul id="city">
   <li>北京</li>
   <li>上海</li>
   <li>天津</li>
   <li>重慶</li>
</ul>
</body>
</html>
3、 事件綁定與解綁
<!DOCTYPE html>
<html>
<head>
   <meta charset="UTF-8">
   <title></title>
   <script src="../js/jquery-3.3.1.min.js" type="text/javascript" charset="utf-8"></script>
   <script type="text/javascript">
       $(function () {
           // 獲取name對(duì)象,綁定click事件
           // $("#name").click(function () {
           //     alert("我被點(diǎn)擊了!");
           // });
?
           // 給name對(duì)象綁定鼠標(biāo)移動(dòng)元素之上事件與鼠標(biāo)移除事件
           // $("#name").mouseover(function () {
           //     alert("鼠標(biāo)來(lái)了!");
           // });
           // $("#name").mouseleave(function () {
           //     alert("鼠標(biāo)走了!");
           // });
?
           // 簡(jiǎn)化操作,鏈?zhǔn)骄幊?br>            // $("#name").mouseover(function () {
           //     alert("鼠標(biāo)來(lái)了");
           // }).mouseleave(function () {
           //     alert("鼠標(biāo)走了");
           // })
?
?
           $("#name").focus();// 讓文本輸入框獲得焦點(diǎn)
           // 表單對(duì)象.submit()   // 讓表單提交
      })
?
   </script>
</head>
<body>
<input id="name" type="text" value="綁定點(diǎn)擊事件">
</body>
</html>
?
<!DOCTYPE html>
<html>
<head>
   <meta charset="UTF-8">
   <title></title>
   <script src="../js/jquery-3.3.1.min.js" type="text/javascript" charset="utf-8"></script>
   <script type="text/javascript">
       $(function () {
           // 使用on綁定事件
           $("#btn").on("click",function () {
               alert("我被點(diǎn)擊了!");
          });
?
           // 使用off解綁事件
           $("#btn2").click(function () {
               // 解除btn按鈕的click綁定事件
               $("#btn").off("click");
          });
      });
?
?
?
   </script>
</head>
<body>
<input id="btn" type="button" value="使用on綁定點(diǎn)擊事件">
<input id="btn2" type="button" value="使用off解綁點(diǎn)擊事件">
</body>
</html>
?
<!DOCTYPE html>
<html>
<head>
   <meta charset="UTF-8">
   <title></title>
   <script src="../js/jquery-3.3.1.min.js" type="text/javascript" charset="utf-8"></script>
   <script src="../js/jquery-migrate-1.0.0.js" type="text/javascript" charset="utf-8"></script>
   <script type="text/javascript">
       $(function () {
           $("#btn").toggle(function () {
               // 改變背景色為綠色
               $("#myDiv").css("backgroundColor","green");
          },function () {
               // 改變背景色為黃色
               $("#myDiv").css("backgroundColor","yellow");
          })
      })
   </script>
</head>
<body>
?
   <input id="btn" type="button" value="事件切換">
   <div id="myDiv" style="width:300px;height:300px;background:pink">
      點(diǎn)擊按鈕變成綠色,再次點(diǎn)擊黃色
   </div>
</body>
</html>
4、案例1:廣告顯示和隱藏
<!DOCTYPE html>
<html>
<head>
   <meta charset="UTF-8">
   <title>廣告的自動(dòng)顯示與隱藏</title>
   <style>
       #content{width:100%;height:500px;background:#999}
   </style>
?
   <!--引入jquery-->
   <script type="text/javascript" src="../js/jquery-3.3.1.min.js"></script>
   <script>
       $(function () {
           // 定義定時(shí)器,3秒之后顯示廣告
           setTimeout(adShow,3000);
           // 定義定時(shí)器,5秒之后隱藏廣告
           setTimeout(adHide,8000);
      });
       // 顯示廣告
       function adShow() {
           $("#ad").show("slow");
      }
       // 隱藏廣告
       function adHide() {
           $("#ad").hide("slow");
      }
   </script>
</head>
<body>
<!-- 整體的DIV -->
<div>
   <!-- 廣告DIV -->
   <div id="ad" style="display: none;">
       <img style="width:100%" src="../img/adv.jpg" />
   </div>
?
   <!-- 下方正文部分 -->
   <div id="content">
      正文部分
   </div>
</div>
</body>
</html>
5、案例2:抽獎(jiǎng)
<!DOCTYPE html>
<html>
<head>
   <meta charset="UTF-8">
   <title>jquery案例之抽獎(jiǎng)</title>
   <script type="text/javascript" src="../js/jquery-3.3.1.min.js"></script>
   <script>
       var img = ["../img/man00.jpg",
           "../img/man01.jpg",
           "../img/man02.jpg",
           "../img/man03.jpg",
           "../img/man04.jpg",
           "../img/man05.jpg",
           "../img/man06.jpg"];
       $(function () {
           $("#startID").prop("disabled",false);
           $("#stopID").prop("disabled",true);
?
           var startId;
           var index;
           $("#startID").click(function () {
               $("#startID").prop("disabled",true);
               $("#stopID").prop("disabled",false);
               startId = setInterval(function () {
                   index = Math.floor(Math.random()*7);
                   $("#img1ID").prop("src",img[index])
              },20);
          });
           $("#stopID").click(function () {
               $("#startID").prop("disabled",false);
               $("#stopID").prop("disabled",true);
               clearInterval(startId);
               $("#img2ID").prop("src",img[index]).hide();
               $("#img2ID").show(1000);
          });
      })
   </script>
</head>
<body>
?
<!-- 小像框 -->
<div style="border-style:dotted;width:160px;height:100px">
   <img id="img1ID" src="../img/man00.jpg" style="width:160px;height:100px"/>
</div>
?
<!-- 大像框 -->
<div
       style="border-style:double;width:800px;height:500px;position:absolute;left:500px;top:10px">
   <img id="img2ID" src="../img/man00.jpg" width="800px" height="500px"/>
</div>
?
<!-- 開始按鈕 -->
<input
       id="startID"
       type="button"
       value="點(diǎn)擊開始"
       style="width:150px;height:150px;font-size:22px"
       onclick="imgStart()">
?
<!-- 停止按鈕 -->
<input
       id="stopID"
       type="button"
       value="點(diǎn)擊停止"
       style="width:150px;height:150px;font-size:22px"
       onclick="imgStop()">
?
?
<script language='javascript' type='text/javascript'>
   //準(zhǔn)備一個(gè)一維數(shù)組,裝用戶的像片路徑
   var imgs = [
       "../img/man00.jpg",
       "../img/man01.jpg",
       "../img/man02.jpg",
       "../img/man03.jpg",
       "../img/man04.jpg",
       "../img/man05.jpg",
       "../img/man06.jpg"
  ];
?
</script>
</body>
</html>
6、01-jQuery對(duì)象進(jìn)行方法擴(kuò)展
<!DOCTYPE html>
<html>
<head>
   <meta charset="UTF-8">
   <title>01-jQuery對(duì)象進(jìn)行方法擴(kuò)展</title>
   <script src="../js/jquery-3.3.1.min.js" type="text/javascript" charset="utf-8"></script>
   <script type="text/javascript">
       // 使用jQuery插件,給jq添加兩個(gè)方法,check()選中所有復(fù)選框,uncheck()取消所有選中
       // 定義jQuery對(duì)象的插件
       $.fn.extend({
           // 定義一個(gè)check方法,所有的jq對(duì)象都可以調(diào)用該方法
           check:function () {
               this.prop("checked",true);
          },
           uncheck:function () {
               this.prop("checked",false);
          }
      });
       $(function () {
           $("#btn-check").click(function () {
               $("input[type='checkbox']").check();
          });
           $("#btn-uncheck").click(function () {
               $("input[type='checkbox']").uncheck();
          });
      })
   </script>
</head>
<body>
<input id="btn-check" type="button" value="點(diǎn)擊選中復(fù)選框" onclick="checkFn()">
<input id="btn-uncheck" type="button" value="點(diǎn)擊取消復(fù)選框選中" onclick="uncheckFn()">
<br/>
<input type="checkbox" value="football">足球
<input type="checkbox" value="basketball">籃球
<input type="checkbox" value="volleyball">排球
?
</body>
</html>
7、02-jQuery全局進(jìn)行方法擴(kuò)展
<!DOCTYPE html>
<html>
<head>
   <meta charset="UTF-8">
   <title>01-jQuery對(duì)象進(jìn)行方法擴(kuò)展</title>
   <script src="../js/jquery-3.3.1.min.js" type="text/javascript" charset="utf-8"></script>
   <script type="text/javascript">
       //對(duì)全局方法擴(kuò)展2個(gè)方法,擴(kuò)展min方法:求2個(gè)值的最小值;擴(kuò)展max方法:求2個(gè)值最大值
       $.extend({
           max:function (a,b) {
               return a >= b ? a : b;
          },
           min:function (a,b) {
               return a <= b ? a : b;
          }
      });
?
       var max = $.max(2,3);
       alert(max);
       var min = $.min(1,8);
       alert(min);
   </script>
</head>
<body>
</body>
</html>


0 人點(diǎn)贊