jQuery API の fadeToggle( duration ) は、指定した要素が非表示の場合、その要素を、duration に指定した速度のフェードインのアニメーションで表示し、指定した要素が表示されている場合、その要素を、duration に指定した速度のフェードアウトのアニメーションで非表示にするメソッド。
記述方法
「セレクター」の要素が非表示の場合、「セレクター」の要素を、「速度」に指定した速度のフェードインのアニメーションで表示する。
「セレクター」の要素が表示されている場合、「セレクター」の要素を、「速度」に指定した速度のフェードアウトのアニメーションで非表示にする。
「速度」は、ミリ秒単位の数字、もしくは、'slow'、'normal'、'fast' の文字列で指定できる。
実装例(サンプル)
fadeToggle( 2000 ) ボタンをクリックすると:
フェードインの2秒間のアニメーションで表示
もしくは、
フェードアウトの2秒間のアニメーションで非表示
fadeToggle( 'fast' ) ボタンをクリックすると:
フェードインの速いアニメーションで表示
もしくは、
フェードアウトの速いアニメーションで非表示
実装例(サンプル)の動作について
「 fadeToggle( 2000 ) 」ボタンをクリックすると、「fadeToggle( 2000 ) ボタンをクリックすると: 」の下に黄色のボックスを、2秒間のフェードインのアニメーションで表示する。「 fadeToggle( 2000 ) 」ボタンを再度クリックすると、黄色のボックスを、2秒間のフェードアウトのアニメーションで非表示にする。
「 fadeToggle( 'fast' ) 」ボタンをクリックすると、「fadeToggle( 'fast' ) ボタンをクリックすると: 」の下に黄色のボックスを、速いフェードインのアニメーションで表示する。「 fadeToggle( 'fast' ) 」ボタンを再度クリックすると、黄色のボックスを、速いフェードアウトのアニメーションで非表示にする。
実装例(サンプル)のソースコード
JavaScript
<!--
jQuery( function() {
jQuery( '#jquery-api-fadeToggle' ) . click( function() {
jQuery( '#jquery-api-fadeToggle-contents' ) . fadeToggle( 2000 );
} );
jQuery( '#jquery-api-fadeToggle-fast' ) . click( function() {
jQuery( '#jquery-api-fadeToggle-fast-contents' ) . fadeToggle( 'fast' );
} );
} );
// -->
</script>
CSS
<!--
#jquery-api-fadeToggle-contents,
#jquery-api-fadeToggle-fast-contents {
display: none;
padding: 10px;
width: 400px;
color: red;
background-color: yellow;
border: 1px solid gray;
border-radius: 10px;
}
-->
</style>
HTML
<p>fadeToggle( 2000 ) ボタンをクリックすると:</p>
<div id="jquery-api-fadeToggle-contents">
<p>フェードインの2秒間のアニメーションで表示</p>
<p>もしくは、</p>
<p>フェードアウトの2秒間のアニメーションで非表示</p>
</div>
<p><button id="jquery-api-fadeToggle-fast">fadeToggle( 'fast' )</button></p>
<p>fadeToggle( 'fast' ) ボタンをクリックすると:</p>
<div id="jquery-api-fadeToggle-fast-contents">
<p>フェードインの速いアニメーションで表示</p>
<p>もしくは、</p>
<p>フェードアウトの速いアニメーションで非表示</p>
</div>