そのため、enyo.ViewController は、デフォルトで、document.body に renderInto する必要があり、それを使用して enyo.Application の種類をアプリケーションの「開始点」として定義します。
Enyo の実装は、処理するすべてのビュー (または enyo.Control) に対して必ずしも適切なコントローラーを用意する必要がないという意味で、必ずしも「純粋な」MVC ではありません。Enyo は常に、一種のハイブリッド ビュー/コントローラー システムをコントロール自体に焼き付けてきました。
そうは言っても、実装に対する最近の変更により、「ビュー」を所有する「コントローラー」へのイベントのバブリングが削除されました。これは、多くの不要なオーバーヘッドが発生するためです。実際、さまざまなコントローラーへのアプリグローバル参照として enyo.Application の種類から「コントローラー」ブロックを削除し、代わりに、「従来の」Enyo 開発の典型としてコンポーネント ブロックに配置します。
したがって、現在の考えでは、ビューは以前と同じようにイベントを処理しますが、さまざまな「コントローラー」とモデルのプロパティにバインドできます。
現在でも、本当に必要な場合は MVC アーキテクチャを作成できますが、システムは「関心の分離」方法論 (MVC、MVP、MVVM など) をサポートするのに十分な柔軟性を備えています。
私の現在のやり方は、いくつかのこと (Web サービス要求の作成など) を行うための「コントローラー」を作成し、取得したデータからモデルを構築し、それらをコレクションに追加することです。モデルごとにいくつかの行を自動的に生成するデータベース対応コントロール (enyo.DataRepeater や enyo.DataList など)。
この簡単な例を見てみましょう: http://github.com/clinuz/college-football ですが、アプリ全体のコントローラーからコンポーネントへの切り替えに伴い、最新ではない可能性があることに注意してください。また、DataRepeater/List の「コントローラー」プロパティを削除し、「コレクション」に変更します。
さらにヒントが必要な場合はお知らせください。実装を最終決定するまでの間、ドキュメントの不足によりこれが困難になっていることは承知しています。我慢してください!