ホームページ ウェブフロントエンド htmlチュートリアル css3アニメーションとjqueryを使用する場合の注意点animation_html/css_WEB-ITnose

css3アニメーションとjqueryを使用する場合の注意点animation_html/css_WEB-ITnose

Jun 24, 2016 pm 12:34 PM

少し前にデモを書いていたときに、要素に css3 または jquery アニメーションを追加するときに、アニメーションが終了する前に要素の css 属性を正確に取得できないという問題が発生しました。

1. CSS3 アニメーションのディスカッション

まずコードを見てください:

html:

<div id="hehe"></div><button class="change">change</button><button class="get">get</button>
ログイン後にコピー

css:

#hehe {    width: 100px;    height: 100px;    padding: 10px;    background: red;    -webkit-transition: all 10s ease-out;    -moz-transition: all 10s ease-out;    -o-transition: all 10s ease-out;    transition: all 10s ease-out;}
ログイン後にコピー

js:

$(document).ready(function() {    $('.change').click(function() {        $('#hehe').width(400);    });    $('.get').click(function() {        console.log($('#hehe').width());    });});
ログイン後にコピー

コードは非常に簡単です。 hehe div に赤い背景色を追加し、css3 でアニメーション スムージング効果の css3 trasition を使用しました (css3 trasition の使用方法については、この記事を参照してください: http://www.w3cplus.com/content/css3-transition 、非常に詳細に書かれています)。つまり、幅、高さ、背景、フォントなどの CSS プロパティを変更すると、イーズアウト (速度低下) スムーズ トランジション効果が 10 秒間持続します。たとえば、変更ボタンをクリックすると、hehe の幅が 10 秒かかり、徐々に 400px まで増加し、アニメーション効果が生成されます。

ここで質問が来ます: アニメーションの進行中に取得ボタンをクリックします。コンソールによって出力される「へへ」の幅はどれくらいですか?

変更をクリックすると、要素を検査するときに「

」が表示されたので、最初は 400 だと思いました。答えは「いいえ」です。得られるのは、アニメーション中のクリックの瞬間の「ふふふ」の幅です。

コンソール コードを変更します。

console.log($('#hehe').css('width');
ログイン後にコピー

これで、アニメーション プロセス全体で、[get] をクリックすると 400 ピクセルが取得されることがわかります。これは、jquery の width() が要素の幅をリアルタイムで取得するのに対し、css('width') は単位も持っているため、単に要素の CSS 値を取得することを示しています。

2.Jqueryアニメーションの議論

jqueryアニメーションは理解しやすいです。 css3 トランジションの css コードを削除し、jquery animate に置き換えます。

$(document).ready(function() {    console.log($('#hehe').width());    $('.change').click(function() {        $('#hehe').animate({width: "400px"}, 10000);    });    $('.get').click(function() {        console.log($('#hehe').width());    });});
ログイン後にコピー

jquery アニメーションは実際に要素にスタイルを動的に追加するため、hehe の幅は、width() を使用して取得するか css('width') を使用して取得するかに応じて動的に変化します。ただし、width を使用して取得される幅には単位 px がなく、すべて整数ですが、css('width') を使用して取得される幅には単位があり、小数点以下の桁数が大きくなります。長さ。

まとめ:

ここまで議論しましたが、重要なのは、アニメーションを使用するときに、まだ変化している CSS 属性、特に幅と高さをすぐに取得すると、問題が発生しやすいということです。これらの要素のプロパティを取得するには、アニメーションが終了するまで待つ必要があります。または、アニメーション化する CSS プロパティを指定することもできます。たとえば、アニメーションの幅と高さを取得したいが、実際に必要なアニメーション効果は背景色の変更だけである場合、css3 トランジションを記述するときに次のように記述できます

-webkit-transition: background .7s ease-out;-moz-transition: background .7s ease-out;-o-transition: background .7s ease-out;transition: background .7s ease-out;
ログイン後にコピー

ちなみに、アニメーション効果は背景色に反映されるだけで、幅や高さは動的に変化しません。

同様に、CSS3 アニメーションの他の 2 つの効果、トランスフォーム (http://www.w3cplus.com/content/css3-transform) とアニメーション (http://www.w3cplus.com/content/css3-animation ) については、また、アニメーションを使用している場合でも、transition と同じであることがわかりました。css('width') を使用して取得される幅も変化します。興味のある学生はぜひ試してみてください。

そのため、css3 アニメーションを使用する場合は、アニメーションの影響にもっと注意を払う必要があります。

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

ホット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ヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

&lt; Progress&gt;の目的は何ですか 要素? &lt; Progress&gt;の目的は何ですか 要素? Mar 21, 2025 pm 12:34 PM

この記事では、HTML&lt; Progress&gt;について説明します。要素、その目的、スタイリング、および&lt; meter&gt;との違い要素。主な焦点は、&lt; Progress&gt;を使用することです。タスクの完了と&lt; Meter&gt; statiの場合

&lt; datalist&gt;の目的は何ですか 要素? &lt; datalist&gt;の目的は何ですか 要素? Mar 21, 2025 pm 12:33 PM

この記事では、HTML&lt; Datalist&GT;について説明します。オートコンプリートの提案を提供し、ユーザーエクスペリエンスの改善、エラーの削減によりフォームを強化する要素。

&lt; meter&gt;の目的は何ですか 要素? &lt; meter&gt;の目的は何ですか 要素? Mar 21, 2025 pm 12:35 PM

この記事では、html&lt; meter&gt;について説明します。要素は、範囲内でスカラーまたは分数値を表示するために使用され、Web開発におけるその一般的なアプリケーション。それは差別化&lt; Meter&gt; &lt; Progress&gt;およびex

ビューポートメタタグとは何ですか?レスポンシブデザインにとってなぜそれが重要なのですか? ビューポートメタタグとは何ですか?レスポンシブデザインにとってなぜそれが重要なのですか? Mar 20, 2025 pm 05:56 PM

この記事では、モバイルデバイスのレスポンシブWebデザインに不可欠なViewportメタタグについて説明します。適切な使用により、最適なコンテンツのスケーリングとユーザーの相互作用が保証され、誤用が設計とアクセシビリティの問題につながる可能性があることを説明しています。

&lt; iframe&gt;の目的は何ですか タグ?使用する際のセキュリティ上の考慮事項は何ですか? &lt; iframe&gt;の目的は何ですか タグ?使用する際のセキュリティ上の考慮事項は何ですか? Mar 20, 2025 pm 06:05 PM

この記事では、&lt; iframe&gt;外部コンテンツをWebページ、その一般的な用途、セキュリティリスク、およびオブジェクトタグやAPIなどの代替案に埋め込む際のタグの目的。

HTMLは初心者のために簡単に学ぶことができますか? HTMLは初心者のために簡単に学ぶことができますか? Apr 07, 2025 am 12:11 AM

HTMLは、簡単に学習しやすく、結果をすばやく見ることができるため、初心者に適しています。 1)HTMLの学習曲線はスムーズで簡単に開始できます。 2)基本タグをマスターして、Webページの作成を開始します。 3)柔軟性が高く、CSSおよびJavaScriptと組み合わせて使用​​できます。 4)豊富な学習リソースと最新のツールは、学習プロセスをサポートしています。

HTML、CSS、およびJavaScriptの役割:コアの責任 HTML、CSS、およびJavaScriptの役割:コアの責任 Apr 08, 2025 pm 07:05 PM

HTMLはWeb構造を定義し、CSSはスタイルとレイアウトを担当し、JavaScriptは動的な相互作用を提供します。 3人はWeb開発で職務を遂行し、共同でカラフルなWebサイトを構築します。

HTMLでの開始タグの例は何ですか? HTMLでの開始タグの例は何ですか? Apr 06, 2025 am 12:04 AM

Anexampleapalofastartingtaginhtmlis、それはaperginsaparagraph.startingtagsaresentionentientiontheyinitiateelements、definetheirtypes、およびarecrucialforurturingwebpagesandcontingthomedomを構築します。

See all articles