私はEmber.JSを試していますが、(かなり)基本的な例でも、これまでRequire.JSで使用するのに非常に苦労しています。
まず第一に、Require.JSは(私が思うに)Ember.JSに見られる2つの弱点を改善することになっていると言いたいです:
- 特に個別のjsファイルでアプリを整理する
- 不要なコードを読み込まない
基本的に、ヘッダー/コンテンツ/フッターを使用してアプリを表示しようとしています。したがって、アプリを作成するときは、ApplicationControllerとApplicationViewをバインドし、ビューがテンプレートを処理します。これは、ヘッダーとフッターを(非常に簡単に)表示するのに最適です。
次に、インデックスのテンプレートをレンダリングしようとしています(たとえば)。IndexView/ IndexController(たとえば)を動的にロードして、ルートにバインドしたいと思います。それは私が苦労しているところです。
IndexViewをApp.IndexViewとして直接設定することでこれを行う簡単な方法を見つけましたが、このソリューションの問題は、IndexViewをロードすると、(text.jsプラグインを使用して)インデックステンプレートファイルのコンテンツもロードすることです。私の例ではそれで問題ありませんが、複雑なWebサイトを構築しようとしているため、Webサイトをロードするときにすべてのテンプレートをロードすることになります。これは、Require.JSが避けようとしていたことです。
私はここでどこが間違っていますか?ルーティングに応じてテンプレートを動的にロードするにはどうすればよいですか?