検索
ホームページウェブフロントエンドjsチュートリアルjqueryのアニメーション効果とアニメーションキューのまとめ(コード付き)

この記事では、jquery のアニメーション エフェクトとアニメーション キューの概要を説明します (コード付き)。必要な方は参考にしていただければ幸いです。

基本効果

.hide([duration ] [,easing ] [,complete ])

は、パラメータを指定しないと、表示属性

$('.target').hide()//等同于
$('.target').css('display', 'none')

.show()

を直接設定するのに使用されます。要素を表示するために使用されます。使用法は hide と同様ですhide类似

$('#btn-box1').on('click',function(){
  $('.box').show('normal')
})

.toggle()

用来切换元素的隐藏、显示,类似于toggleClass,用法和showhide类似

渐变效果

.fadeIn()

以淡入的方式显示匹配元素

$('#btn-box3').on('click',function(){
  $('.box').fadeIn()
})

.fadeOut()

以淡出的方式显示匹配元素

$('#btn-box4').on('click',function(){
  $('.box').fadeOut()
})

.fadeTo()

调整匹配元素的透明度,方法通过匹配元素的不透明度做动画效果

$('#book').fadeTo('slow', 0.5, function() {  // Animation complete.
});

滑动效果

.slideDown() / .slideUp()

用滑动动画显示一个匹配元素

$('#btn-box5').on('click',function(){
  $('.box').slideDown()
})

$('#btn-box6').on('click',function(){
  $('.box').slideUp()
})

回调同步 与 异步

如以下案例

回调同步

即在整个动画结束之后,出现'hide',即为同步

$('#btn-box1').on('click',function(){
  $('.box').hide('normal', funciton(){        console.log('hide')
  })
})

异步

即只要事件触发瞬间(即按下btn),就出现'hide',即为异步

$('#btn-box1').on('click',function(){
  $('.box').hide('normal')   console.log('hide')
})

具体参考 demo 案例 1 中的案例

$('#action1').on('click',function(){  var $box = $('.box')  //回调地狱写法
  $box.hide(1000, function(){
    $box.show(1000, function(){
      $box.fadeOut('slow', function(){
        $box.fadeIn('slow', function(){
          $box.slideUp(function(){
            $box.slideDown(function(){              console.log('动画执行完毕')
              $('#wrap1').text('动画执行完毕')
            })
          })
        })
      })
    })
  })
})

$('#action2').on('click',function(){  var $box = $('.box')  //使用jQuery动画队列写法
  $box.hide(1000)
      .show(1000)
      .fadeOut('slow')
      .fadeIn('slow')
      .slideUp()
      .slideDown(function(){        console.log('真的执行完毕了')
        $('#wrap2').text('真的执行完毕了')  //最后执行同步回调
      })    console.log('动画完毕了吗?')  //动画才刚开始,在动画队列创建的时候,就输出这句话,异步
    $('#wrap2').text('动画完毕了吗?')
})

jQuery 动画队列

动画队列可以说是动画执行的一个顺序机制,当我们对一个对象添加多次动画效果时后,添加的动作就会被放入这个动画队列中,等前面的动画完成后再开始执行。

动画队列机制和执行顺序

  1. 对于一组元素上的动画效果,有如下两种情况:

  • 当在一个animate()方法中应用多个属性时,动画是同时发生的。

  • 当以链式的写法应用动画方法时,动画是按照顺序发生的。

  1. 对于多组元素上的动画效果,有如下情况:

  • 默认情况下,动画都是同时发生的。

  • 当以回调的形式应用动画方式时,动画是按照回调顺序发生的。

即参考之前的 回调同步、异步。

以上是整个动画的调度一个流程,其实都是利用队列异步的空闲然后执行同步的代码,这样在处理上是没有浪费资源的,而且精确度也是最高的。

自定义动画

当基础效果、渐变效果、滑动效果动画不能满足需求的时候,jQuery 提供了自定义动画行为的方法

.animate( properties [, duration ] [, easing ] [, complete ] )

properties是一个 CSS属性和值 的对象,动画将根据这组对象移动。

$('#btn4').click(function(){
  $('.box').animate({    left: '150px'
  },1000)
  .animate({    left: '150px',    top: '150px'
  },1000)
  .animate({    left: '0',    top: '150px'
  },1000)
  .animate({    left: '0',    top: '0'
  },1000)
})

.clearQueue()

清除 动画队列 中未执行的动画

.stop( [clearQueue ] [, jumpToEnd ] )

停止当前正在运行的动画
里面的参数

  • clearQueue:即是.clearQueue()方法,决定是否清楚 动画队列 中未执行的动画

  • jumpToEnd:即是决定是否展示当前一帧动画是否执行到最后

这两个参数默认都为false
即.stop()等同于.stop(false,false)

.stop(false,false)

动画序列中共有 4 个序列,当执行到 动画序列2 的时候 使用.stop(),序列2 立即停止,并执行 动画序列3 ,执行完之后,执行动画序列4。

进入 demo 点击 auto 之后,再点击 .stop() 即可查看效果

.stop(true,false)

动画序列中共有 4 个序列,当执行到 动画序列2 的时候 使用.stop(true,false),序列2 立即停止,由于参数 [clearQueue]是 true 因此后面的也动画序列也全部清空,不会再往下执行动画序列。因此动画会停留在 动画序列2 .stop(true,false)rrreee

.toggle()🎜🎜 は要素の非表示と表示を切り替えるために使用されます。toggleClass と同様です。 show code> は <code>show code> に似ており、<code>hide
🎜🎜グラデーション効果🎜🎜.fadeIn() に似ています🎜🎜フェードイン方式で一致する要素を表示します🎜rrreee 🎜.fadeOut()🎜🎜 一致する要素をフェードアウトで表示する 要素 🎜rrreee🎜.fadeTo()🎜🎜 一致する要素の不透明度をアニメーション化して、一致する要素の透明度を調整する🎜rrreee🎜 スライド効果🎜🎜.slideDown () / .slideUp()🎜🎜スライドアニメーションを使用して一致する要素を表示します🎜rrreee🎜コールバック同期と非同期🎜🎜次の場合のように🎜🎜コールバック同期🎜🎜つまり、アニメーション全体が終了した後、' Hide' が表示されます。これは同期🎜rrreee🎜非同期🎜🎜です。つまり、イベントがトリガーされた瞬間 (つまり、ボタンを押したとき)、'hide' が表示されます。これは非同期です🎜rrreee🎜 詳細については、デモケース 1 のケースを参照してください🎜rrreee

🎜🎜jQuery アニメーション キュー🎜🎜アニメーション キューは、アニメーションの実行のシーケンシャルなメカニズムと言えます。オブジェクトに複数のアニメーション効果を追加すると、追加されたアクションはアニメーション キューに入れられ、前のアニメーションが完了するまで実行は開始されません。 🎜

🎜🎜アニメーション キューのメカニズムと実行順序 🎜

  1. 🎜 要素のグループに対するアニメーション効果には、次の 2 つの状況があります: 🎜
  • 🎜 1 つの animate() メソッドで複数のプロパティを適用すると、アニメーションが同時に発生します。 🎜
  • 🎜チェーンライティングでアニメーションメソッドを適用すると、アニメーションが順番に発生します。 🎜
  1. 🎜 要素の複数のグループに対するアニメーション効果の場合、次のような状況があります: 🎜
  • 🎜デフォルトでは、アニメーションはすべて同時に発生します。 🎜
  • 🎜アニメーション メソッドがコールバックの形式で適用される場合、アニメーションはコールバックの順序で発生します。 🎜
  • 🎜前のコールバックの同期と非同期を参照してください。 🎜🎜上記はアニメーション全体をスケジュールするプロセスですが、実際にはキューの非同期アイドル時間を使用して同期コードを実行するため、処理に無駄がなく、精度が高くなります。最高。
    🎜🎜カスタムアニメーション🎜🎜基本的なエフェクト、グラデーションエフェクト、スライディングエフェクトアニメーションではニーズを満たせない場合、jQueryはアニメーションの動作をカスタマイズするメソッドを提供します🎜🎜.animate(properties [,duration][,eaing][, complete ] )🎜🎜properties は CSS のプロパティと値のオブジェクトであり、アニメーションはこのオブジェクトのセットに従って動きます。 🎜rrreee🎜.clearQueue()🎜🎜アニメーションキュー内の未実行のアニメーションをクリアします🎜🎜.stop( [clearQueue ] [, JumpToEnd ] )🎜🎜現在実行中のアニメーションを停止します
    内のパラメータ 🎜
    • 🎜clearQueue: これは、アニメーション キュー内の未実行のアニメーションをクリアするかどうかを決定する .clearQueue() メソッドです🎜
    • 🎜jumpToEnd : つまり、アニメーションの現在のフレームを表示するかどうか、およびアニメーションを最後まで実行するかどうかを決定します🎜
    🎜両方のパラメータはデフォルトで false です
    つまり、 .stop() は同等ですto .stop(false,false)🎜

    .stop(false,false)

    🎜 アニメーションシーケンス 2 を実行する場合は、.stop()を使用します。 > シーケンス 2 はすぐに停止し、アニメーション シーケンス 3 を実行します。実行後、アニメーション シーケンス 4 を実行します。 🎜

    🎜🎜 デモ auto をクリックし、.stop() をクリックします。 以上です。エフェクトを確認できます🎜

    .stop(true,false)

    🎜アニメーション シーケンス 2 を実行する場合は、.stop( true 、 false) の場合、シーケンス 2 はすぐに停止します。パラメータ [clearQueue]true であるため、後続のアニメーション シーケンスもすべてクリアされ、それ以降は実行されません。アニメーションシーケンス。したがって、アニメーションはアニメーション シーケンス 2 .stop(true,false) に留まります。 🎜

    demoを入力してautoをクリックし、.stop(true,false)をクリックして効果を確認します

    .stop(true,true)

    アニメーションシーケンスには4つのシーケンスがあります。シーケンス 2 で .stop(true,true) を使用します。パラメータ [clearQueue]true であるため、後続のアニメーション シーケンスもすべて実行されます。をクリアすると、アニメーション シーケンスはそれ以上実行されなくなります。パラメータ [jumpToEnd]true であるため、アニメーション シーケンス 2 自体が終了するはずの場所で終了します。 .stop(true,true),由于参数 [clearQueue]是 true 因此后面的也动画序列也全部清空,不会再往下执行动画序列。由于参数 [jumpToEnd]也是 true ,因此 最后会停留在 动画序列2 本身应该结束的位置。

    进入 demo 点击 auto 之后,再点击 .stop(true,true) 即可查看效果

    .finish()

    停止当前动画,并清除 动画队列 中所有未完成的动画,最终展示 动画队列 最后一帧的最终状态

    进入 demo 点击 auto 之后,再点击 .finish()

    demoを入力してください autoをクリックしてください その後、.stop(true,true) をクリックして効果を確認します

    .finish()

    現在のアニメーションを停止し、未使用のアニメーションをすべてクリアします。アニメーション キュー 完成したアニメーションには、最終的にアニメーション キューの最後のフレームの最終状態が表示されます

    demo を入力し、auto をクリックし、.finish() をクリックして効果を確認してください

    関連する推奨事項: 🎜🎜🎜共有よく使用される jQuery アニメーション イベントとアニメーション関数_jquery🎜🎜🎜🎜JQuery アニメーション スクロール ページのトップに戻るアニメーション効果 (Chrome と互換性あり)_jquery🎜🎜🎜🎜🎜jQuery アニメーション効果コレクション🎜🎜

    以上がjqueryのアニメーション効果とアニメーションキューのまとめ(コード付き)の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

    声明
    この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
    JavaScriptの文字列文字を交換しますJavaScriptの文字列文字を交換しますMar 11, 2025 am 12:07 AM

    JavaScript文字列置換法とFAQの詳細な説明 この記事では、javaScriptの文字列文字を置き換える2つの方法について説明します:内部JavaScriptコードとWebページの内部HTML。 JavaScriptコード内の文字列を交換します 最も直接的な方法は、置換()メソッドを使用することです。 str = str.replace( "find"、 "置換"); この方法は、最初の一致のみを置き換えます。すべての一致を置き換えるには、正規表現を使用して、グローバルフラグGを追加します。 str = str.replace(/fi

    独自のJavaScriptライブラリを作成および公開するにはどうすればよいですか?独自のJavaScriptライブラリを作成および公開するにはどうすればよいですか?Mar 18, 2025 pm 03:12 PM

    記事では、JavaScriptライブラリの作成、公開、および維持について説明し、計画、開発、テスト、ドキュメント、およびプロモーション戦略に焦点を当てています。

    ブラウザでのパフォーマンスのためにJavaScriptコードを最適化するにはどうすればよいですか?ブラウザでのパフォーマンスのためにJavaScriptコードを最適化するにはどうすればよいですか?Mar 18, 2025 pm 03:14 PM

    この記事では、ブラウザでJavaScriptのパフォーマンスを最適化するための戦略について説明し、実行時間の短縮、ページの負荷速度への影響を最小限に抑えることに焦点を当てています。

    jQueryマトリックス効果jQueryマトリックス効果Mar 10, 2025 am 12:52 AM

    マトリックスの映画効果をあなたのページにもたらしましょう!これは、有名な映画「The Matrix」に基づいたクールなJQueryプラグインです。プラグインは、映画の古典的な緑色のキャラクター効果をシミュレートし、画像を選択するだけで、プラグインはそれを数値文字で満たされたマトリックススタイルの画像に変換します。来て、それを試してみてください、それはとても面白いです! それがどのように機能するか プラグインは画像をキャンバスにロードし、ピクセルと色の値を読み取ります。 data = ctx.getimagedata(x、y、settings.greasize、settings.greasize).data プラグインは、写真の長方形の領域を巧みに読み取り、jQueryを使用して各領域の平均色を計算します。次に、使用します

    ブラウザ開発者ツールを使用してJavaScriptコードを効果的にデバッグするにはどうすればよいですか?ブラウザ開発者ツールを使用してJavaScriptコードを効果的にデバッグするにはどうすればよいですか?Mar 18, 2025 pm 03:16 PM

    この記事では、ブラウザ開発者ツールを使用した効果的なJavaScriptデバッグについて説明し、ブレークポイントの設定、コンソールの使用、パフォーマンスの分析に焦点を当てています。

    シンプルなjQueryスライダーを構築する方法シンプルなjQueryスライダーを構築する方法Mar 11, 2025 am 12:19 AM

    この記事では、jQueryライブラリを使用してシンプルな画像カルーセルを作成するように導きます。 jQuery上に構築されたBXSLiderライブラリを使用し、カルーセルをセットアップするために多くの構成オプションを提供します。 今日、絵のカルーセルはウェブサイトで必須の機能になっています - 1つの写真は千の言葉よりも優れています! 画像カルーセルを使用することを決定した後、次の質問はそれを作成する方法です。まず、高品質の高解像度の写真を収集する必要があります。 次に、HTMLとJavaScriptコードを使用して画像カルーセルを作成する必要があります。ウェブ上には、さまざまな方法でカルーセルを作成するのに役立つ多くのライブラリがあります。オープンソースBXSLiderライブラリを使用します。 BXSLiderライブラリはレスポンシブデザインをサポートしているため、このライブラリで構築されたカルーセルは任意のものに適合させることができます

    JavaScriptによる構造マークアップの強化JavaScriptによる構造マークアップの強化Mar 10, 2025 am 12:18 AM

    キーポイントJavaScriptを使用した構造的なタグ付けの強化は、ファイルサイズを削減しながら、Webページコンテンツのアクセシビリティと保守性を大幅に向上させることができます。 JavaScriptを効果的に使用して、Cite属性を使用して参照リンクを自動的にブロック参照に挿入するなど、HTML要素に機能を動的に追加できます。 JavaScriptを構造化されたタグと統合することで、ページの更新を必要としないタブパネルなどの動的なユーザーインターフェイスを作成できます。 JavaScriptの強化がWebページの基本的な機能を妨げないようにすることが重要です。 高度なJavaScriptテクノロジーを使用できます(

    Angularを使用してCSVファイルをアップロードおよびダウンロードする方法Angularを使用してCSVファイルをアップロードおよびダウンロードする方法Mar 10, 2025 am 01:01 AM

    データセットは、APIモデルとさまざまなビジネスプロセスの構築に非常に不可欠です。これが、CSVのインポートとエクスポートが頻繁に必要な機能である理由です。このチュートリアルでは、Angular内でCSVファイルをダウンロードおよびインポートする方法を学びます

    See all articles

    ホットAIツール

    Undresser.AI Undress

    Undresser.AI Undress

    リアルなヌード写真を作成する AI 搭載アプリ

    AI Clothes Remover

    AI Clothes Remover

    写真から衣服を削除するオンライン AI ツール。

    Undress AI Tool

    Undress AI Tool

    脱衣画像を無料で

    Clothoff.io

    Clothoff.io

    AI衣類リムーバー

    AI Hentai Generator

    AI Hentai Generator

    AIヘンタイを無料で生成します。

    ホットツール

    Dreamweaver Mac版

    Dreamweaver Mac版

    ビジュアル Web 開発ツール

    DVWA

    DVWA

    Damn Vulnerable Web App (DVWA) は、非常に脆弱な PHP/MySQL Web アプリケーションです。その主な目的は、セキュリティ専門家が法的環境でスキルとツールをテストするのに役立ち、Web 開発者が Web アプリケーションを保護するプロセスをより深く理解できるようにし、教師/生徒が教室環境で Web アプリケーションを教え/学習できるようにすることです。安全。 DVWA の目標は、シンプルでわかりやすいインターフェイスを通じて、さまざまな難易度で最も一般的な Web 脆弱性のいくつかを実践することです。このソフトウェアは、

    ドリームウィーバー CS6

    ドリームウィーバー CS6

    ビジュアル Web 開発ツール

    EditPlus 中国語クラック版

    EditPlus 中国語クラック版

    サイズが小さく、構文の強調表示、コード プロンプト機能はサポートされていません

    SublimeText3 Linux 新バージョン

    SublimeText3 Linux 新バージョン

    SublimeText3 Linux 最新バージョン