jQuery API の slideDown( duration, easing ) は、指定した要素が非表示の場合、その要素を、duration に指定した速度のスライドダウンで、easing に指定したイージング関数名のアニメーションで表示するメソッド。
記述方法
「セレクター」の要素が非表示の場合、「セレクター」の要素を、「速度」に指定した速度で、「イージング関数名」で指定したアニメーション動作のスライドダウンで表示する。
「速度」は、ミリ秒単位の数字、もしくは、'slow'、'normal'、'fast' の文字列で指定できる。
「イージング関数名」は、’linear’、’swing’ の文字列で指定できる。イージング関数は、加速度を加味したような動作パターン。jQuery にデフォルトで用意されているのは、linear と swing のシンプルな動作パターンだけだが、jQuery Easing Plugin などの jQuery プラグインを導入することで、使える動作パターンを増やすことができる。
実装例(サンプル)
slideDown( 2000, 'swing' ) / slideUp( 2000, 'swing' ) ボタンをクリックすると:
スライドダウンの2秒間のアニメーションで表示
もしくは、
スライドアップの2秒間のアニメーションで非表示
イージング関数名は、'swing'
slideDown( 'fast', 'swing' ) / slideUp( 'fast', 'swing' ) ボタンをクリックすると:
スライドダウンの速いアニメーションで表示
もしくは、
スライドアップの速いアニメーションで非表示
イージング関数名は、'swing'
実装例(サンプル)の動作について
「 slideDown( 2000, ‘swing’ ) / slideUp( 2000, ‘swing’ ) 」ボタンをクリックすると、「slideDown( 2000, ‘swing’ ) / slideUp( 2000, ‘swing’ ) ボタンをクリックすると: 」の下に黄色のボックスを、2秒間のスライドダウンのアニメーションで表示する。「 slideDown( 2000, ‘swing’ ) / slideUp( 2000, ‘swing’ ) 」ボタンを再度クリックすると、黄色のボックスを、2秒間のスライドアップのアニメーションで非表示にする。
「 slideDown( 'fast', 'swing' ) / slideUp( 'fast', 'swing' ) 」ボタンをクリックすると、「slideDown( 'fast', 'swing' ) / slideUp( 'fast', 'swing' ) ボタンをクリックすると: 」の下に黄色のボックスを、速いスライドダウンのアニメーションで表示する。「 slideDown( 'fast', 'swing' ) / slideUp( 'fast', 'swing' ) 」ボタンを再度クリックすると、黄色のボックスを、速いスライドアップのアニメーションで非表示にする。
アニメーション動作は、何れも、'swing'。
実装例(サンプル)のソースコード
JavaScript
<!--
jQuery( function() {
jQuery( '#jquery-api-slideDown' ) . click( function() {
if ( jQuery( '#jquery-api-slideDown-contents' ) . is( ':hidden' ) ) {
jQuery( '#jquery-api-slideDown-contents' ) . slideDown( 2000, 'swing' );
} else {
jQuery( '#jquery-api-slideDown-contents' ) . slideUp( 2000, 'swing' );
}
} );
jQuery( '#jquery-api-slideDown-fast' ) . click( function() {
if ( jQuery( '#jquery-api-slideDown-fast-contents' ) . is( ':hidden' ) ) {
jQuery( '#jquery-api-slideDown-fast-contents' ) . slideDown( 'fast', 'swing' );
} else {
jQuery( '#jquery-api-slideDown-fast-contents' ) . slideUp( 'fast', 'swing' );
}
} );
} );
// -->
</script>
CSS
<!--
#jquery-api-slideDown-contents,
#jquery-api-slideDown-fast-contents {
display: none;
padding: 10px;
width: 400px;
color: red;
background-color: yellow;
border: 1px solid gray;
border-radius: 10px;
}
-->
</style>
HTML
<p>slideDown( 2000, 'swing' ) / slideUp( 2000, 'swing' ) ボタンをクリックすると:</p>
<div id="jquery-api-slideDown-contents">
<p>スライドダウンの2秒間のアニメーションで表示</p>
<p>もしくは、</p>
<p>スライドアップの2秒間のアニメーションで非表示</p>
<p>イージング関数名は、'swing'</p>
</div>
<p><button id="jquery-api-slideDown-fast">slideDown( 'fast', 'swing' ) / slideUp( 'fast', 'swing' )</button></p>
<p>slideDown( 'fast', 'swing' ) / slideUp( 'fast', 'swing' ) ボタンをクリックすると:</p>
<div id="jquery-api-slideDown-fast-contents">
<p>スライドダウンの速いアニメーションで表示</p>
<p>もしくは、</p>
<p>スライドアップの速いアニメーションで非表示</p>
<p>イージング関数名は、'swing'</p>
</div>