Web の初心者からよく聞かれる質問は「どのフレームワークを使用すればよいですか?」ですが、この質問に対する「正しい」答えはなく、主な議論は通常、AngularJS と jQuery の違いについてです。しかし、それらを比較することは、ある意味、リンゴとオレンジを比較するようなものであり、Web アプリケーションの場合、主要な Web フレームワークのいずれかを使用する明確な理由はありません。 jQuery よりも AngularJS が優先されるいくつかのシナリオを次に示します。
DOM 操作が二次的な場合
jQuery は主に DOM のスキャンと操作に重点を置いています。一般的な例は、AJAX から返された結果を前処理された HTML を通じて既存の DIV に追加するなど、ユーザー操作を通じて DOM 要素を追加および変更することです。しかし、AngularJS では、開発の焦点はデータのプレゼンテーションにあります。双方向データ バインディングを使用すると、DOM を削除して再構築することなく、データ更新が自動的に行われます。 DOM 操作を完全に回避することは不可能ですが、AngularJS を使用すると、jQuery のみを使用する場合よりも DOM 操作の処理が少なくなります。
効率を重視する場合
AngularJS は習得が少し難しいですが、開発者にとっては非常に効率的です。 AngularJS の多くの機能は、開発者の生産性の向上に重点を置いています。たとえば、単体テスト用の拡張サポートが組み込まれています。テストに重点を置いた機能により単体テストが簡素化され、開発者はより堅牢で信頼性の高いコードの作成に集中できるようになります。さらに、DOM 操作をプログラム ロジックから切り離すことで、開発者は「方法」ではなく「なぜ」に集中できるようになります。通常、これにより、短いながらも安定したデバッグが容易なコードが生成されます。
記述インターフェイスを使用する場合
jQuery を使用するときによく発生する問題は、より厳密に言うと、このプロセスの結果が目的の結果になるようにコンピューターに指示することです。ただし、記述的プログラミングはその逆で、必要な結果をコンピューターに伝え、それを達成する方法をコンピューターに決定させます。 JavaScript は一般に命令型アプローチで設計されていますが、HTML (および AngularJS が HTML に追加するディレクティブ) は記述的プログラミング専用に設計されています。 AngularJS を使用してプログラミングすると、最終的には記述的なプログラミングを使用することになります。これは、HTML の本来の設計意図により沿ったものになります。つまり、表示したいものをコンピューターに伝え、コンピューターに特定の詳細を処理させることになります。このプログラミング方法を採用すると、特定のタスクを完了するために必要なコードの行数が大幅に削減され、コードが読みやすくなり、保守が容易になります。
結論
上で述べたように、AngularJS と jQuery は多くの点で比較できません。 2 つのフレームワークは異なる設計目標を持っており、異なる問題を解決します。そうは言っても、データ分析ではなくデータの表示とメンテナンスに重点を置いたアプリケーションを開発する開発者の生産性は大幅に向上しており、これらの分野では AngularJS が jQuery よりもはるかに優れています。最終的にどのフレームワークを選択するかは、組織の能力や使用するツールのコア コンポーネントに関連する多くの要因によって決まります。ただし、いずれの場合でも、インターネット アプリケーション開発者の生産性を向上させ、メンテナンス コストを削減するには、AngularJS が最適な選択です。 。