jquery的事件沒有on,js的有。javascript
<html lang="en"> <head> <meta charset="UTF-8"> <title>魔降風雲變</title> <style> #box{ width: 200px; height: 200px; background-color: red; display: none; } </style> </head> <body> <button id="btn">動畫</button> <div id="box"></div> <script type="text/javascript" src="js/jquery.js" charset="utf-8"></script> <script type="text/javascript"> $('#btn').click(function () { $('#box').show() }) </script> </body> </html>
按鈕.click事件。默認不顯示的內容.show(),顯示出來css
一開始是沒有的:html
點擊一下就出現了。java
show中能夠添加毫秒,1000毫秒是一秒。由小變大緩慢顯示jquery
<html lang="en"> <head> <meta charset="UTF-8"> <title>魔降風雲變</title> <style> #box{ width: 200px; height: 200px; background-color: red; display: none; } </style> </head> <body> <button id="btn">動畫</button> <div id="box"></div> <script type="text/javascript" src="js/jquery.js" charset="utf-8"></script> <script type="text/javascript"> $('#btn').click(function () { $('#box').show(2000) }) </script> </body> </html>
$('#btn').click(function () { $('#box').show(2000) })
<html lang="en"> <head> <meta charset="UTF-8"> <title>魔降風雲變</title> <style> #box{ width: 200px; height: 200px; background-color: red; /*display: none;*/ } </style> </head> <body> <button id="btn">動畫</button> <div id="box"></div> <script type="text/javascript" src="js/jquery.js" charset="utf-8"></script> <script type="text/javascript"> $('#btn').click(function () { $('#box').hide(2000) }) </script> </body> </html>
$('#btn').click(function () { $('#box').hide(2000) })
<html lang="en"> <head> <meta charset="UTF-8"> <title>魔降風雲變</title> <style> #box{ width: 200px; height: 200px; background-color: red; display: none; } </style> </head> <body> <button id="btn">動畫</button> <div id="box"></div> <script type="text/javascript" src="js/jquery.js" charset="utf-8"></script> <script type="text/javascript"> $('#btn').click(function () { if($(this).text()==='顯示'){ //jq節點對象.text() 獲取節點文本 $(this).text('隱藏') //jq節點對象.text('內容') 修改節點的文本 $('#box').show(2000) //jq節點對象.show()顯示display:none的內容 }else { //jq節點對象.show(2000) 指定時間由小到大顯示display:none的內容 $(this).text('隱藏');{ $(this).text('顯示') //jq節點對象.hide() 隱藏顯示的內容 $('#box').hide(2000) //jq節點對象.hide(2000)指定時間由大到小隱藏顯示的內容 } // if小花else花是判斷語句。 對象.事件(函小花)是綁定事件 小中if條件事件無。 } }) </script> </body> </html>
文件比圖片變化快,想要圖片放大或縮小以後再變文字:json
<script type="text/javascript"> $('#btn').click(function () { if($(this).text()==='顯示'){ $('#box').show(2000,function () { $('#btn').text('隱藏') //對象.show(毫秒,這麼多毫秒以後作的函數) } ) //不能用$(this),它在這裏不是btn }else { $(this).text('隱藏');{ $('#box').hide(2000,function (){ //對象.hide(毫秒,這麼多毫秒以後作的函數) $('#btn').text('顯示') }) } } }) </script>
三、toggle()記錄點擊次數ide
點擊一下變化一下。當給toggle一個時間參數的時候,若是點擊次數過快,他會記錄點擊次數。若是你中止點擊了,可是記錄的次數還沒執行完,他會繼續執行直到點擊次數次執行結束函數
<html lang="en"> <head> <meta charset="UTF-8"> <title>魔降風雲變</title> <style> #box{ width: 200px; height: 200px; background-color: red; display: none; } </style> </head> <body> <button id="btn">顯示</button> <div id="box"></div> <script type="text/javascript" src="js/jquery.js" charset="utf-8"></script> <script type="text/javascript"> $('#btn').click(function () { $('#box').toggle(1000) }) </script> </body> </html>
<script type="text/javascript"> $('#btn').click(function () { $('#box').toggle(1000) }) </script>
這時須要添加stop方法,先中止掉再開。動畫
$('#box').stop().toggle(1000)
使用場景:this
原文連接:https://www.cnblogs.com/majj/p/9113627.html
jQuery提供的一組網頁中常見的動畫效果,這些動畫是標準的、有規律的效果;同時還提供給咱們了自定義動畫的功能。
方式一:
$("div").show();
解釋:無參數,表示讓指定的元素直接顯示出來。其實這個方法的底層就是經過display: block;
實現的。
方式二:
$('div').show(3000);
解釋:經過控制元素的寬高、透明度、display屬性,逐漸顯示,2秒後顯示完畢。
方式三:
$("div").show("slow");
參數能夠是:
slow 慢:600ms
normal 正常:400ms
fast 快:200ms
解釋:和方式二相似,也是經過控制元素的寬高、透明度、display屬性,逐漸顯示。
方式四:
//show(毫秒值,回調函數; $("div").show(5000,function () { alert("動畫執行完畢!"); });
解釋:動畫執行完後,當即執行回調函數。
總結:
上面的四種方式幾乎一致:參數能夠有兩個,第一個是動畫的執行時長,第二個是動畫結束後執行的回調函數。
方式參照上面的show()方法的方式。以下:
$(selector).hide(); $(selector).hide(1000); $(selector).hide("slow"); $(selector).hide(1000, function(){});
代碼以下:
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title></title> <style type="text/css"> #box{ width: 200px; height: 200px; background-color: green; border: 1px solid red; display: none; } </style> </head> <body> <div id="box"> </div> <button id="btn">隱藏</button> </body> <script src="jquery-3.3.1.js"></script> <script type="text/javascript"> //jquery 提供了一些方法 show() hide() 控制元素顯示隱藏 var isShow = true; $('#btn').click(function(){ if(isShow){ $('#box').show('slow',function(){ $(this).text('盒子出來了'); $('#btn').text('顯示'); isShow = false; }) }else{ $('#box').hide(2000,function(){ $(this).text(''); $('#btn').text('隱藏'); isShow = true; }) } }) </script> </html>
$('#box').toggle(3000,function(){});
顯示和隱藏的來回切換採用的是toggle()方法:就是先執行show(),再執行hide()。
代碼以下:
$('#btn').click(function(){ $('#box').toggle(3000,function(){ $(this).text('盒子出來了'); if ($('#btn').text()=='隱藏') { $('#btn').text('顯示'); }else{ $('#btn').text('隱藏'); } }); })
一、滑入動畫效果:(相似於生活中的捲簾門)
$(selector).slideDown(speed, 回調函數);
解釋:下拉動畫,顯示元素。
注意:省略參數或者傳入不合法的字符串,那麼則使用默認值:400毫秒(一樣適用於fadeIn/slideDown/slideUp)
二、滑出動畫效果:
$(selector).slideUp(speed, 回調函數);
解釋:上拉動畫,隱藏元素。
三、滑入滑出切換動畫效果:
$(selector).slideToggle(speed, 回調函數);
代碼以下:
<!DOCTYPE html> <html> <head lang="en"> <meta charset="UTF-8"> <title></title> <style> div { width: 300px; height: 300px; display: none; background-color: green; } </style> <script src="jquery-3.3.1.js"></script> <script> $(function () { //點擊按鈕後產生動畫 $("button:eq(0)").click(function () { //滑入動畫: slideDown(毫秒值,回調函數[顯示完畢執行什麼]); $("div").slideDown(2000, function () { alert("動畫執行完畢!"); }); }) //滑出動畫 $("button:eq(1)").click(function () { //滑出動畫:slideUp(毫秒值,回調函數[顯示完畢後執行什麼]); $("div").slideUp(2000, function () { alert("動畫執行完畢!"); }); }) $("button:eq(2)").click(function () { //滑入滑出切換(一樣有四種用法) $("div").slideToggle(1000); }) }) </script> </head> <body> <button>滑入</button> <button>滑出</button> <button>切換</button> <div></div> </body> </html>
使用場景:
一、淡入動畫效果:
$(selector).fadeIn(speed, callback);
做用:讓元素以淡淡的進入視線的方式展現出來。
二、淡出動畫效果:
$(selector).fadeOut(1000);
做用:讓元素以漸漸消失的方式隱藏起來
三、淡入淡出切換動畫效果:
$(selector).fadeToggle('fast', callback);
做用:經過改變透明度,切換匹配元素的顯示或隱藏狀態。
參數的含義同show()方法。
代碼以下:
<!DOCTYPE html> <html> <head lang="en"> <meta charset="UTF-8"> <title></title> <style> div { width: 300px; height: 300px; display: none; /*透明度*/ opacity: 0.5; background-color: red; } </style> <script src="jquery-3.3.1.js"></script> <script> $(function () { //點擊按鈕後產生動畫 $("button:eq(0)").click(function () { // //淡入動畫用法1: fadeIn(); 不加參數 $("div").fadeIn(); // //淡入動畫用法2: fadeIn(2000); 毫秒值 // $("div").fadeIn(2000); // //經過控制 透明度和display //淡入動畫用法3: fadeIn(字符串); slow慢:600ms normal正常:400ms fast快:200ms // $("div").fadeIn("slow"); // $("div").fadeIn("fast"); // $("div").fadeIn("normal"); //淡入動畫用法4: fadeIn(毫秒值,回調函數[顯示完畢執行什麼]); // $("div").fadeIn(5000,function () { // alert("動畫執行完畢!"); // }); }) //滑出動畫 $("button:eq(1)").click(function () { // //滑出動畫用法1: fadeOut(); 不加參數 $("div").fadeOut(); // //滑出動畫用法2: fadeOut(2000); 毫秒值 // $("div").fadeOut(2000); //經過這個方法實現的:display: none; // //經過控制 透明度和display //滑出動畫用法3: fadeOut(字符串); slow慢:600ms normal正常:400ms fast快:200ms // $("div").fadeOut("slow"); // $("div").fadeOut("fast"); // $("div").fadeOut("normal"); //滑出動畫用法1: fadeOut(毫秒值,回調函數[顯示完畢執行什麼]); // $("div").fadeOut(2000,function () { // alert("動畫執行完畢!"); // }); }) $("button:eq(2)").click(function () { //滑入滑出切換 //一樣有四種用法 $("div").fadeToggle(1000); }) $("button:eq(3)").click(function () { //改透明度 //一樣有四種用法 $("div").fadeTo(1000, 0.5, function () { alert(1); }); }) }) </script> </head> <body> <button>淡入</button> <button>淡出</button> <button>切換</button> <button>改透明度爲0.5</button> <div></div> </body> </html>
使用場景,這裏淡入淡出了;
捲簾門效果;
語法:
$(selector).animate({params}, speed, callback);
做用:執行一組CSS屬性的自定義動畫。
第一個參數表示:要執行動畫的CSS屬性(必選)
第二個參數表示:執行動畫時長(可選)
第三個參數表示:動畫執行完後,當即執行的回調函數(可選)
代碼以下:
<!DOCTYPE html> <html> <head lang="en"> <meta charset="UTF-8"> <title></title> <style> div { position: absolute; left: 20px; top: 30px; width: 100px; height: 100px; background-color: green; } </style> <script src="jquery-3.3.1.js"></script> <script> jQuery(function () { $("button").click(function () { var json = {"width": 500, "height": 500, "left": 300, "top": 300, "border-radius": 100}; var json2 = { "width": 100, "height": 100, "left": 100, "top": 100, "border-radius": 100, "background-color": "red" }; //自定義動畫 $("div").animate(json, 1000, function () { $("div").animate(json2, 1000, function () { alert("動畫執行完畢!"); }); }); }) }) </script> </head> <body> <button>自定義動畫</button> <div></div> </body> </html>
$(selector).stop(true, false);
裏面的兩個參數,有不一樣的含義。
第一個參數:
true:後續動畫不執行。
false:後續動畫會執行。
第二個參數:
true:當即執行完成當前動畫。
false:當即中止當前動畫。
PS:參數若是都不寫,默認兩個都是false。實際工做中,直接寫stop()用的多。
案例:鼠標懸停時,彈出下拉菜單(下拉時帶動畫)
<!DOCTYPE html> <html> <head lang="en"> <meta charset="UTF-8"> <title></title> <style type="text/css"> * { margin: 0; padding: 0; } ul { list-style: none; } .wrap { width: 330px; height: 30px; margin: 100px auto 0; padding-left: 10px; background-color: pink; } .wrap li { background-color: green; } .wrap > ul > li { float: left; margin-right: 10px; position: relative; } .wrap a { display: block; height: 30px; width: 100px; text-decoration: none; color: #000; line-height: 30px; text-align: center; } .wrap li ul { position: absolute; top: 30px; display: none; } </style> <script src="jquery-3.3.1.js"></script> <script> //入口函數 $(document).ready(function () { //需求:鼠標放入一級li中,讓他裏面的ul顯示。移開隱藏。 var jqli = $(".wrap>ul>li"); //綁定事件 jqli.mouseenter(function () { $(this).children("ul").stop().slideDown(1000); }); //綁定事件(移開隱藏) jqli.mouseleave(function () { $(this).children("ul").stop().slideUp(1000); }); }); </script> </head> <body> <div class="wrap"> <ul> <li> <a href="javascript:void(0);">一級菜單1</a> <ul> <li><a href="javascript:void(0);">二級菜單2</a></li> <li><a href="javascript:void(0);">二級菜單3</a></li> <li><a href="javascript:void(0);">二級菜單4</a></li> </ul> </li> <li> <a href="javascript:void(0);">二級菜單1</a> <ul> <li><a href="javascript:void(0);">二級菜單2</a></li> <li><a href="javascript:void(0);">二級菜單3</a></li> <li><a href="javascript:void(0);">二級菜單4</a></li> </ul> </li> <li> <a href="javascript:void(0);">三級菜單1</a> <ul> <li><a href="javascript:void(0);">三級菜單2</a></li> <li><a href="javascript:void(0);">三級菜單3</a></li> <li><a href="javascript:void(0);">三級菜單4</a></li> </ul> </li> </ul> </div> </body> </html>
ps:
javascript:void(0); //跟javascript:;效果同樣
上方代碼中,關鍵的地方在於,用了stop函數,再執行動畫前,先停掉以前的動畫。