在知道有animation-play-state這個animation的參數(shù)時,我內(nèi)心是激動的。在得知iOS端并不支持時,一股涼意襲來
animation-play-state
先來介紹一下今天的主角animation-play-state
animation-play-state CSS 屬性定義一個動畫是否運行或者暫停??梢酝ㄟ^查詢它來確定動畫是否正在運行。另外,它的值可以被設(shè)置為暫停和恢復(fù)的動畫的重放。
恢復(fù)一個已暫停的動畫,將從它開始暫停的時候,而不是從動畫序列的起點開始在動畫。
在MDN文檔中了解到,這是一個實驗中的功能,但是其作用還是強大的。既可以控制/獲取元素的動畫狀態(tài)(paused,running)
所以,這個animation的參數(shù)用來控制動畫的播放狀態(tài)再合適不過了。畫外音:你還沒考慮兼容性呢!對!就是這個兼容性問題。在chrome上這個參數(shù)是可以支持的,但是iOS設(shè)備上就不支持了...嘆息。
在iOS上的處理
當(dāng)然不能因為兼容性問題就不用這個參數(shù)了,當(dāng)然不能讓每個iOS用戶去下載一個chrome瀏覽器,當(dāng)然...
那我們怎么解決呢???用JS
通過Window.getComputedStyle()方法,我們可以獲取元素實時的style的CSSStyleDeclaration對象,這個對象表示CSS屬性鍵值對的集合。也就是說我們使用這個方法可以獲取一個正在進行動畫的元素當(dāng)前的style值。
PS:關(guān)于Window.getComputedStyle()方法的值可以在MDN上了解到,這里不展開敘述。給出一個語法的例子(摘自MDN)
let style = window.getComputedStyle(element, [pseudoElt]);
那么具體要怎么做呢?
實現(xiàn)
<p data-height="417" data-theme-id="light" data-slug-hash="ejeLJm" data-default-tab="js,result" data-user="luogao" data-pen-title="animation-play-state" class="codepen">See the Pen <a >animation-play-state</a> by luogao (<a >@luogao</a>) on <a >CodePen</a>.</p>
<script async src="https://static.codepen.io/assets/embed/ei.js"></script>
代碼已經(jīng)在上面的codepen預(yù)覽中展示啦,如果現(xiàn)實不來請點這里??Roy Luo's codepen
大致解釋一下就是:
在元素的外層的包裹元素上添加獲取到的執(zhí)行動畫的元素的style計算屬性,從而讓執(zhí)行動畫的元素暫停下來。
那么在微信小程序中又是如何呢?
其實,最先遇到這個問題是在做小程序的時候。一個播放器的界面,中間一張專輯圖片。在圓形的黑膠唱片邊框中旋轉(zhuǎn)。當(dāng)播放停止,圖片也同時停止旋轉(zhuǎn)。停在當(dāng)前旋轉(zhuǎn)的位置
當(dāng)時看似簡單的一個需求,使用了animation-play-state并且與預(yù)期一樣達到了效果,在模擬器中。
沒錯,洋洋得意的以為完成了需求,結(jié)果真機(iOS)上一測試,原形畢露。
當(dāng)時看到小程序的官方社區(qū)中提到說iOS不支持這個animation-play-state???♂????♂????♂????
幸得殘陽映楓紅在sf的一個問題中的回答讓我找到了方向。感謝之~
值得在最后前一提的是
這里有三個小程序的坑要提一下
- nodesRef.fields(fields, [callback])這個方法需要在基本庫2.1.0(個人感覺不是個該著重考慮的問題)
- 這個方法是異步的(自行感受)
- 應(yīng)該區(qū)分iOS和安卓設(shè)備,進行不同的處理。能不用這個nodesRef.fields方法盡量不要用~
參考
本文作者: Roy Luo
本文鏈接: 微信小程序iOS端如何暫停animated動畫