データの読み込みが完了するまで AngularJS のルート変更をブロックする
AngularJS では、データが完全に読み込まれていない場合、ルート遷移によりちらつきや視覚的なアーティファクトが発生することがあります新しいルートが表示される前に。この問題を軽減するために、必要なデータがすべてフェッチされて処理されるまでルート変更を遅らせることができます。
$routeProvider による Promise の解決
AngularJS の $routeProviderルート変更が発生する前にデータの依存関係を解決できます。ルート設定でresolveプロパティを指定すると、Promiseを返す関数を定義できます。ルートの変更は、ルートに関連付けられたすべての Promise が解決されるまで延期されます。
ProjectsController の例
ProjectsController の次のルート定義を考えてみましょう。
angular.module('app').config(['$routeProvider', function ($routeProvider) { $routeProvider.when('/projects', { templateUrl: 'projects/index.html', controller: 'ProjectsController', resolve: { projects: function (ProjectService) { // Function to fetch project data return ProjectService.query(); }, delay: function ($q, $defer) { // Function to add a delay for demonstration purposes let delay = $q.defer(); $defer(delay.resolve, 1000); return delay.promise; } } }); }]);
この例では、resolve オブジェクトは 2 つを定義しますfunction:
結論
$routeProvider の replace プロパティを利用することで、AngularJS アプリケーションは、移行前にすべてのデータ依存関係が満たされていることを確認することで、ルートのちらつきを効果的に防ぐことができます。新しいルートへ。この技術により、スムーズでちらつきのないナビゲーション エクスペリエンスが提供され、ユーザー エクスペリエンスが大幅に向上します。
以上がデータの待機中に AngularJS でルートのちらつきを防ぐにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。