LoginSignup
4
2

More than 5 years have passed since last update.

CSSのtransitionアニメーションが終わったら関数を実行

Last updated at Posted at 2016-12-12

結論

let time = $(el).css("transition-duration");

if(/ms$/.test(time)){ // msかどうか
  time = parseFloat(time);
} else {
  time = parseFloat(time) * 1000;
} 


setTimeout(()=>{
  // Do something...
}, time);

解説

CSSのtransitionを用いたアニメーションで、animateのコールバック関数みたいにするにはどうするか考えてみました。

要はアニメーションにかかる秒数をsetTimeoutしたらいいのです。

transitionのアニメーションにかかる秒数はCSSのtransition-durationプロパティを取るとわかります。

CSSのtime型のデータには秒とミリ秒が指定できるので、正規表現でミリ秒かどうかを判断して、ミリ秒の場合は1000かけます。

最後に、それをsetTimeoutしたら終わりです。

デモ

JSFiddle

4
2
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
4
2