transitionプロパティのアニメーションで発生するイベント
CSSのtransitionプロパティを使ったアニメーションでは、状況に応じて次の4種類のイベントが発生します。
イベント名 | 発生するタイミング |
---|---|
transitionrun | アニメーションを開始する直前に発生 |
transitionstart | アニメーションを開始したときに発生 |
transitionend | アニメーションが完了したときに発生 |
transitioncancel | アニメーションを途中でキャンセルしたときに発生 |
これらのイベントはtransitionrun、transitionstart、transitionendの順番で発生します。
もしアニメーションが途中でキャンセルされて停止したときにはtransitioncancelが発生しますが、アニメーション完了前にキャンセルがあったときはtransitionendは発生しません。
今回はa要素を使ったボタンを用意してtransitionプロパティを使ったアニメーションを設定し、4種類のイベントをイベントリスナーに登録して発生するタイミングを確認していきます。
ブラウザで表示すると次のようになり、青い「サンプルボタン」にカーソルを乗せるとアニメーションを開始して、その下にイベントに応じたメッセージを表示します。
このページのHTML、CSS、JavaScriptのコードは以下のようになります。
このコードを使ったサンプルページはこちら
HTML コード例
<article id="content1">
<h1>JavaScriptレシピ</h1>
<a class="btn" href="#">サンプルボタン</a>
</article>
CSS コード例
a.btn {
display: inline-block;
padding: 10px 20px;
color: #fff;
text-decoration: none;
border-radius: 5px;
background-color: #4a93cb;
transition-property: background-color;
transition-duration: 1.0s;
transition-timing-function: ease;
}
a.btn:hover {
background-color: #7db7e4;
}
JavaScript コード例
window.addEventListener('DOMContentLoaded', function(){
let btn = document.querySelector(".btn");
btn.addEventListener("transitionrun", function(){
createMessage("Transition Run");
});
btn.addEventListener("transitionstart", function(){
createMessage("Transition Start");
});
btn.addEventListener("transitionend", function(){
createMessage("Transition End");
});
btn.addEventListener("transitioncancel", function(){
createMessage("Transition Cancel");
});
});
// イベントが発生したときにメッセージを表示する
function createMessage(message) {
let p_element = document.createElement("p");
p_element.textContent = message;
let article_element = document.getElementById("content1");
article_element.append(p_element);
}
CSSではclass属性「btn」のボタンに対してtransition-propertyプロパティ、transition-durationプロパティ、transition-timing-functionプロパティをそれぞれ指定しています。
アニメーションの長さはtiming-durationプロパティで1秒の設定です。
JavaScriptのアニメーションで発生する4種類のイベントに対してはイベントリスナーで登録し、全てcreateMessageメソッドを実行します。
createMessageメソッドは受け取った文字列を使ってp要素を作成し、ページ上のarticle要素の末尾に追加していきます。
これで、イベントが発生したときにイベントに応じたメッセージがページに表示されるようになります。
ボタンにカーソルを乗せると、イベントはまずtransitionrun、transitionstartの2つが順番に発生して、transition-durationプロパティで指定した1秒後にアニメーションが終了したタイミングでtransitionendが発生します。
transitionendが発生する前にボタンからカーソルが離れたときはキャンセル扱いになってtransitioncancelが発生します。