「労働者が自分の仕事をうまくやりたいなら、まず自分の道具を研ぎ澄まさなければなりません。」 - 孔子、「論語。陸霊公」
表紙 > プログラミング > AngularJS $watch は動的ナビゲーションの高さ調整でタイマーをどのように置き換えることができますか?

AngularJS $watch は動的ナビゲーションの高さ調整でタイマーをどのように置き換えることができますか?

2024 年 11 月 5 日に公開
ブラウズ:125

How Can AngularJS $watch Replace Timers in Dynamic Navigation Height Adjustment?

AngularJS を監視する高さでのタイマーの回避

AngularJS プログラマは、ナビゲーションの高さが動的である場合に、応答性の高いナビゲーションという課題に直面することがよくあります。これにより、ナビゲーションの高さの変化に応じてコンテンツのマージントップ値を調整する必要が生じます。

以前は、ナビゲーションの高さの変化を検出するためにタイマーが使用されていましたが、このアプローチには欠点がありました。コンテンツのマージントップの調整に遅れが生じます。

幸いなことに、AngularJS の $watch 機能を利用するという、より良いアプローチが存在します。タイマーの代わりに、ウォッチャーが「emHeightSource」に登録され、各 $digest サイクル中に呼び出されます。ウォッチャーは '__height' プロパティを更新します。

'emHeightTarget' では、別のウォッチャーが '__height' を監視し、それに応じてマージントップの値を更新し、コンテンツのマージントップがスムーズに、ナビゲーションと同期して変更されるようにします。 height.

ウォッチャーを使用して洗練されたコードは次のとおりです:

/*
 * Get notified when height changes and change margin-top
 */
.directive( 'emHeightTarget', function() {
    return {
        link: function( scope, elem, attrs ) {

            scope.$watch( '__height', function( newHeight, oldHeight ) {
                elem.attr( 'style', 'margin-top: '   (58   newHeight)   'px' );
            } );
        }
    }
} )

/*
 * Checks every $digest for height changes
 */
.directive( 'emHeightSource', function() {

    return {
        link: function( scope, elem, attrs ) {

            scope.$watch( function() {
                scope.__height = elem.height();
            } );
        }
    }

} )
最新のチュートリアル もっと>

免責事項: 提供されるすべてのリソースの一部はインターネットからのものです。お客様の著作権またはその他の権利および利益の侵害がある場合は、詳細な理由を説明し、著作権または権利および利益の証拠を提出して、電子メール [email protected] に送信してください。 できるだけ早く対応させていただきます。

Copyright© 2022 湘ICP备2022001581号-3