slideToggle( duration, easing )

jQuery API の slideToggle( duration, easing ) は、duration に指定した速度で、easing に指定したイージング関数名の動作パターンのスライドダウン/スライドアップのアニメーションで、指定した要素の表示/非表示を切り替えるメソッド。

記述方法

jQuery( セレクター ) . slideToggle( 速度, イージング関数名 );

「セレクター」の要素が非表示の場合、「セレクター」の要素を、「速度」に指定した速度で、「イージング関数名」に指定したイージング関数名の動作パターンのスライド・ダウン・アニメーションで表示する。

「セレクター」の要素が表示されている場合、「セレクター」の要素を、「速度」に指定した速度で、「イージング関数名」に指定したイージング関数名の動作パターンのスライド・アップ・アニメーションで非表示にする。

「速度」は、ミリ秒単位の数字、もしくは、'slow'、'normal'、'fast' の文字列で指定できる。

「イージング関数名」は、'linear'、'swing' の文字列で指定できる。イージング関数は、加速度を加味したような動作パターン。jQuery にデフォルトで用意されているのは、linear と swing のシンプルな動作パターンだけだが、jQuery Easing Plugin などの jQuery プラグインを導入することで、使える動作パターンを増やすことができる。

実装例(サンプル)

slideToggle( 2000, 'swing' ) ボタンをクリックすると:

スライドダウンの2秒間のアニメーションで表示

もしくは、

スライドアップの2秒間のアニメーションで非表示

slideToggle( 'fast', 'swing' ) ボタンをクリックすると:

スライドダウンの速いアニメーションで表示

もしくは、

スライドアップの速いアニメーションで非表示

実装例(サンプル)の動作について

「 slideToggle( 2000, 'swing' ) 」ボタンをクリックすると、「slideToggle( 2000, 'swing' ) ボタンをクリックすると: 」の下に黄色のボックスを、2秒間のスライドダウンのアニメーションで表示する。「 slideToggle( 2000, 'swing' ) 」ボタンを再度クリックすると、黄色のボックスを、2秒間のスライドアップのアニメーションで非表示にする。

「 slideToggle( 'fast', 'swing' ) 」ボタンをクリックすると、「slideToggle( 'fast', 'swing' ) ボタンをクリックすると: 」の下に黄色のボックスを、速いスライドダウンのアニメーションで表示する。「 slideToggle( 'fast', 'swing' ) 」ボタンを再度クリックすると、黄色のボックスを、速いスライドアップのアニメーションで非表示にする。

実装例(サンプル)のソースコード

JavaScript

<script>
<!--
jQuery( function() {
    jQuery( '#jquery-api-slideToggle' ) . click( function() {
        jQuery( '#jquery-api-slideToggle-contents' ) . slideToggle( 2000, 'swing' );
    } );
    jQuery( '#jquery-api-slideToggle-fast' ) . click( function() {
        jQuery( '#jquery-api-slideToggle-fast-contents' ) . slideToggle( 'fast', 'swing' );
    } );
} );
// -->
</script>

CSS

<style>
<!--
#jquery-api-slideToggle-contents,
#jquery-api-slideToggle-fast-contents {
    display: none;
    padding: 10px;
    width: 400px;
    color: red;
    background-color: yellow;
    border: 1px solid gray;
    border-radius: 10px;
}
-->
</style>

HTML

<p><button id="jquery-api-slideToggle">slideToggle( 2000, 'swing' )</button></p>
<p>slideToggle( 2000, 'swing' ) ボタンをクリックすると:</p>
<div id="jquery-api-slideToggle-contents">
    <p>スライドダウンの2秒間のアニメーションで表示</p>
    <p>もしくは、</p>
    <p>スライドアップの2秒間のアニメーションで非表示</p>
</div>
<p><button id="jquery-api-slideToggle-fast">slideToggle( 'fast', 'swing' )</button></p>
<p>slideToggle( 'fast', 'swing' ) ボタンをクリックすると:</p>
<div id="jquery-api-slideToggle-fast-contents">
    <p>スライドダウンの速いアニメーションで表示</p>
    <p>もしくは、</p>
    <p>スライドアップの速いアニメーションで非表示</p>
</div>

スポンサード リンク

カテゴリー: API, JavaScript, jQuery, エフェクト, スライド タグ: パーマリンク