jquery運動

在前面封裝的move.js框架,在jquery中有同樣封裝好的功能animate()。使用方法非常類似,下面我們看看animate的使用方法,有了原生的運動方法,然后再使用jquery的運動方法就會變得非常簡單。

animate()語法

$(selector).animate({params},speed,callback);

必需的params參數定義形成動畫的css屬性。
可選的speed參數規定效果的時長。它可以取以下值“slow”,“fast”或毫秒。
可選的callback參數是動畫完成后所執行的函數名稱。
注意:如需對位置進行操作,要記得首先把元素的CSS position屬性設置為relative、fixed或absoult。

用animate()方法做一個多屬性同時運動的例子

<!DOCTYPE html>
<html>
<head><style>#div1{height:100px;width:100px;background:#f00;position:absolute;}</style>
<script src="https://code.jquery.com/jquery-3.3.1.min.js">
</script>
<script>$(document).ready(function(){$("button").click(function(){$("div").animate({left:'250px',height:'150px',width:'150px'},300,function(){$("div").animate({opacity:'0.5'})});});});
</script>
</head><body><button>開始動畫</button>
<div id="div1">
</div></body>
</html>

通過上面的代碼我們可以看出jquery運動可以做多屬性運動,也可以做鏈式運動,也可以做單屬性運動。調用方式跟我們用原始javascript封裝的框架一樣。區別在于這里可以設定速度。json串中帶px等單位。jquery運動做鏈式運動的時候可以使用回調函數,多寫幾個運動。animate的更多使用方法可以參考http://www.w3school.com.cn/jq...。

注意:是否可以用animate()方法來操作所有css屬性?是的,幾乎可以!不過,需要記住一件重要的事情:當使用animate()時,必須使用Camel標記法書寫所有的屬性名,比如,必須使用paddingLeft而不是padding-left,使用marginRight而不是margin-right等等。同時,色彩動畫并不包含在核心jQuery庫中。如果需要生成顏色動畫,您需要從jQuery.com下載Color Animations插件。

animate()使用預定義的值——"show"/"hide"/"toggle"

<!DOCTYPE html>
<html><head><title>jquery animate可以使用預定義的值</title><script src="https://code.jquery.com/jquery-3.3.1.min.js"></script><style>#div1{background: #f00;width: 100px;height: 100px;position: absolute;}</style><script>$(function(){$("button").click(function(){$("div").animate({height:"toggle"});})})</script></head><body><button>開始動畫</button><div id="div1"></div></body>
</html>

animate()使用隊列功能——類似于我們自己封裝的鏈式運動

我們封裝的運動沒有隊列功能。但是jquery提供針對動畫的隊列功能。這就意味著如果您在彼此之后編寫多個animate()調用,jquery會創建包含這些方法調用的內部隊列。然后逐一運動這些animate調用。

<!DOCTYPE html>
<html><head><title>animate隊列調用</title><script src="https://code.jquery.com/jquery-3.3.1.min.js"></script><style>#div1{width: 100px;height: 100px;background: #f00;position: absolute;}</style><script>$(function(){$("button").click(function(){var div=$("div");div.animate({height:"300px",opacity:"0.4"},"slow");div.animate({width:"300px",opacity:"0.8"},"slow");div.animate({height:"100px",opacity:"0.4"},"slow");div.animate({width:"100px",opacity:"0.8"},"slow");})})</script></head><body><button>開始動畫</button><div id="div1"></div></body>
</html>

stop()停止動畫或效果

stop()方法用于停止動畫或效果,在它們完成之前。
stop()方法適用于所有jquery效果函數,包括滑動、淡入淡出和自定義動畫。
語法:

$(selector).stop(stopAll,goToEnd);
  • 可選參數stopAll規定是否應該清除動畫隊列。默認是false,即僅停止活動的動畫,允許任何排入隊列的動畫向后執行。
  • 可選參數goToEnd規定是否立即完成當前動畫。默認是false。

所以,默認的stop()會清除在被選元素上指定的當前動畫。

<!DOCTYPE html>
<html>
<head><title>stop()清除當前運動</title><script src="https://code.jquery.com/jquery-3.3.1.min.js"></script><script>$(function() {$("#flip").click(function() {$("#panel").slideDown(5000);});$("#stop").click(function() {$("#panel").stop();});});</script><style type="text/css">#panel,#flip {padding: 5px;text-align: center;background-color: #e5eecc;border: solid 1px #c3c3c3;}#panel {padding: 50px;display: none;}</style>
</head>
<body><button id="stop">停止滑動</button><div id="flip">點擊這里,向下滑動面板</div><div id="panel">Hello world!</div>
</body>
</html>

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/282254.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/282254.shtml
英文地址,請注明出處:http://en.pswp.cn/news/282254.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

Session的原理,大型網站中Session方面應注意什么?

一、Session和Cookie的區別 Session是在服務器端保持會話數據的一種方法&#xff08;通常用于pc端網站保持登錄狀態&#xff0c;手機端通常會使用token方式實現&#xff09;&#xff0c;存儲在服務端。 Cookie是在客戶端保持用戶數據&#xff0c;存儲位置是客戶端&#xff08…

MySQL5.5讀寫分離之mysql-proxy

通常一個網站在初期訪問量都比較小&#xff0c;所以一般的小架構足以支撐。但是&#xff0c;當網站逐漸發展起來后&#xff0c;隨之而來的是大量的訪問&#xff0c;這時候最先出現的瓶頸就是數據庫了。因為數據的寫入讀取操作&#xff08;I/O&#xff09;是集群中響應速度最慢的…

兩圓相交求面積 hdu5120

轉載 兩圓相交分如下集中情況&#xff1a;相離、相切、相交、包含。 設兩圓圓心分別是O1和O2&#xff0c;半徑分別是r1和r2&#xff0c;設d為兩圓心距離。又因為兩圓有大有小&#xff0c;我們設較小的圓是O1。 相離相切的面積為零&#xff0c;代碼如下&#xff1a; [cpp] view …

Python_list部分功能介紹

x.append():在列表尾部添加一個元素 x.clear():把列表清空 x.count():判斷某個元素出現的次數 x.extend():合并兩個列表&#xff0c;或者一個元組 x.index():獲取元素下標 x.insert():指定下標添加元素 x.pop():移除某一元素&#xff0c;移除的元素可獲取 x.remove():移除指定的…

一招解決開發環境問題 —— 遠程容器開發指南

前言使用C作為主要開發語言的程序猿們應該會認同搭建開發環境是一件煩人的事情。為了編譯一個程序不僅需要下載各種依賴包&#xff0c;還可能面臨本地系統不兼容、編譯器版本不一致、包版本沖突等各種問題。筆者在運營iLogtail開源社區的過程中發現開發和調試環境問題也是成員問…

php中常用的加密方式

一、md5 要說php中的最常用的加密方式&#xff0c;md5可以說是當仁不讓。 使用起來也很簡單便捷。 注&#xff1a;使用方式請看 六、md5加密方式的漏洞及解決方案 二、password_hash 作為php5.5以上版本專門用于加密的方式&#xff0c;自然有其獨到之處。 使用方式鏈接&a…

解決問題的策略-分而治之

一個宏偉的目標看上去遙不可及&#xff0c;這怎么可能做成呢&#xff1f;但是你把這些目標分解成一個一個的小目標&#xff0c;小目標再往下分解&#xff0c;分解到最后&#xff0c;分解成細枝末節時你會發現&#xff0c;這事其實是可以做的。這個做成了再往下走一步&#xff0…

UITabBarController的基本原理及使用(一)

前言 UITabBarController在iOS開發中是一個高頻使用的控制器&#xff0c;典型的案例如QQ、微信均使用UITabBarController布局。本文將從一個新建工程&#xff0c;和大家一起了解UITabBarController的基本原理和使用方法。 基本概念 UITabBarController能夠方便地管理多個控制器…

word-vba-microsoft(中英文)

中文 https://msdn.microsoft.com/zh-cn/vba/word-vba/articles/view-displaypageboundaries-property-word 英文 https://msdn.microsoft.com/en-us/vba/word-vba/articles/view-displaypageboundaries-property-word轉載于:https://www.cnblogs.com/itzxy/p/7625915.html

C# 多線程ThreadPool用法舉例

概述ThreadPool是.Net Framework 2.0版本中出現的。自從Task出來以后&#xff0c;ThreadPool已經很少用了&#xff0c;但是一些老的代碼或者一些古老的程序猿還是會用到他&#xff0c;所以我們可以不用它&#xff0c;但是還是有必須學習和了解他.ThreadPool用法舉例static void…

Mysql實現主從復制(一主雙從)

一、環境介紹 LNMP&#xff08;centos7&#xff0c;mysql5.6&#xff09; vmware workstation pro配置了3個虛擬機&#xff0c;均安裝了LNMP環境&#xff1a; master&#xff1a; 192.168.0.105 slave&#xff1a; 192.168.0.106 、192.168.0.107 二、原理 &a…

Elasticsearch學習筆記-04.3批處理

除了創建、更新和刪除個別文檔&#xff0c;Elasticsearch還提供了使用_bulk API的上述操作的批量操作方法。這個功能很重要&#xff0c;因為他提供了一種有效的機制來在盡可能少的網絡傳輸過程中執行多次操作。 作為一個快速示例&#xff0c;下面的命令在一次批量操作中索引了兩…

接口文檔神器Swagger(下篇)

本文來自網易云社區作者&#xff1a;李哲二、Swagger-springmvc原理解析上面介紹了如何將springmvc和springboot與swagger結合&#xff0c;通過簡單配置生成接口文檔&#xff0c;以及介紹了swagger提供的一些注解。下面將介紹swagger是如何做到與springmvc結合&#xff0c;自動…

php實現mysql分表

一、場景說明 1、為什么要進行分表 隨著數據量的不斷增大&#xff0c;一張表中的數據肯定也會越來越多&#xff0c;甚至達到百萬甚至千萬級。我們通常會通過搭建mysql集群&#xff08;主從同步&#xff09;&#xff0c;讀寫分離來實現優化數據庫查詢執行效率。 但是由于數據…

利用python進行數據分析D1——ch02引言

基礎的課程還沒學完&#xff0c;就來這本了&#xff0c;因為我平時的研究還是以數據的處理為主。把自己的事做好做細致讀了一下介紹部分&#xff0c;下載書里用到的數據&#xff0c;下載地址&#xff1a;https://github.com/wesm/pydata-book 如果你需要完成以下幾大類任務&…

記一次Memory Leak分析

起因&#xff1a;最近公司的一個web產品遇到了內存溢出&#xff0c;于是開始著手調查。調查&#xff1a;首先當務之急是找到那個或那些API導致Memory Leak&#xff0c;這個應該不難&#xff0c;根據監控分析&#xff0c;在內存上升時間段內有哪些API被訪問&#xff0c;再就是根…

【t057】任務分配

Time Limit: 1 second Memory Limit: 128 MB 【問題描述】 現有n個任務,要交給A和B完成。每個任務給A或給B完成&#xff0c;所需的時間分別為ai和bi。問他們完成所有的任務至少要多少時間。 【輸入格式】 第一行一個正整數n&#xff0c;表示有n個任務。 接下來有n行&#xf…

LeetCode 366. Find Leaves of Binary Tree

實質就是求每個節點的最大深度。用一個hash表記錄&#xff0c;最后輸出。 class Solution { public:unordered_map<TreeNode *,int> hash; // record the level from bottomvector<vector<int>> findLeaves(TreeNode* root) {vector<vector<int>>…

C#比較對象的相等性

對于相等的機制全部不同&#xff0c;這取決于比較的是引用類型還是值類型。以下分別介紹引用類型和值類型的相等性。1.比較引用類型的相等性 System.Object定義了三種不同的方法&#xff0c;來比較對象的相等性&#xff1a;ReferenceEquals()和兩個版本號的Equals()。再加上比較…

WebSocket教程

一、為什么需要 WebSocket&#xff1f; 初次接觸 WebSocket 的人&#xff0c;都會問同樣的問題&#xff1a;我們已經有了 HTTP 協議&#xff0c;為什么還需要另一個協議&#xff1f;它能帶來什么好處&#xff1f; 答案很簡單&#xff0c;因為 HTTP 協議有一個缺陷&#xff1a…