ドキュメント レベルのカスタマイズのデータ モデル
更新 : 2007 年 11 月
対象 |
---|
このトピックの情報は、指定された Visual Studio Tools for Office プロジェクトおよび Microsoft Office のバージョンにのみ適用されます。 プロジェクトの種類
Microsoft Office のバージョン
詳細については、「アプリケーションおよびプロジェクトの種類別の使用可能な機能」を参照してください。 |
Visual Studio Tools for Office のドキュメント レベルのソリューションは、データを Office ドキュメントのビューから分離することを主要な目的としています。データとは、数値やテキストなど、ドキュメントに格納されている情報のことです。ビューとは、Microsoft Office Word および Microsoft Office Excel のユーザー インターフェイスとオブジェクト モデルを意味します。
Visual Studio Tools for Office では、データをデータ アイランド (データ キャッシュともいいます) として埋め込むことによって、ドキュメント レベルのカスタマイズのビューから分離できます。そのため Word または Excel を起動せずに、データを直接読み取ったり変更したりすることができます。これは、Microsoft Office がインストールされていないサーバー上のドキュメントのデータを変更する場合に役立ちます。Word および Excel はクライアント環境での使用が想定されており、サーバー上で実行するようには設計されていません。
ドキュメント レベルのカスタマイズの詳細については、「Office ソリューションの開発の概要」および「ドキュメント レベルのカスタマイズのアーキテクチャ」を参照してください。
キャッシュ データ プログラミング モデルの概要
データ アイランドには、ソリューション内のオブジェクトのうち特定の要件を満たすものを含めることができます。そうしたオブジェクトには、DataSet オブジェクト、DataTable オブジェクト、および XmlSerializer クラスによってシリアル化できるオブジェクトが含まれます。詳細については、キャッシュされたデータ を参照してください。
キャッシュされたデータのビューを提供するには、ドキュメント上の Windows フォーム コントロールとホスト コントロールをデータ アイランド内のオブジェクトにバインドします。データ アイランドとデータがバインドされたコントロールは、それらの間のデータ バインディングによって同期が維持されます。コントロールから独立した検証コードをデータに追加することもできます。詳細については、「コントロールへのデータのバインド」を参照してください。
ホスト コントロールは、Word および Excel のオブジェクト モデルに属するネイティブ オブジェクトの拡張バージョンです。ネイティブ オブジェクトとは異なり、ホスト コントロールはマネージ データ オブジェクトに直接バインドできます。詳細については、「ホスト項目とホスト コントロールの概要」および「Office ドキュメントでの Windows フォーム コントロールの概要」を参照してください。
サーバー上のキャッシュされたデータへのアクセス
ドキュメント内のキャッシュされたデータにアクセスするには、ServerDocument クラスを使用します。このクラスは Visual Studio Tools for Office ランタイムに含まれており、Excel や Word を実行せずにサーバー上で使用できます。キャッシュされたデータを変更した後でユーザーがドキュメントを開くと、そのデータにバインドされているコントロールに変更が自動的に反映されるため、更新されたデータが表示されます。詳細については、「サーバー上のドキュメント内のデータへのアクセス」を参照してください。
クライアントでの表示にのみ Excel と Word を使用し、サーバーのデータへの書き込みには使用しません。Excel や Word をサーバーにインストールしておく必要はありません。このため、スケーラビリティが向上し、データ アイランドが含まれるドキュメントを迅速にバッチ処理できます。
オフラインで使用するためのデータ キャッシング
データをデータ アイランドに格納することにより、オフライン作業が可能になります。ユーザーが最初にドキュメントを開いたとき、またはサーバーからドキュメントを要求したときに、データ アイランドには最新のデータが格納されています。データ アイランドはドキュメント内にキャッシュされた後で、オフラインで利用可能になります。ユーザー (ユーザーのコード) は、オンライン接続できない状態であってもデータを操作できます。ユーザーが再接続すると、データの変更がサーバーのデータ ソースに反映されます。
キャッシュされたデータとカスタム XML 部分の比較
カスタム XML 部分は、任意の XML コードをドキュメントに格納する手段として、2007 Microsoft Office system で導入されました。カスタム XML 部分はデータ キャッシュと同じシナリオの多くで役に立ちますが、Visual Studio Tools for Office データ アイランドとカスタム XML 部分の間にはいくつか相違点があります。カスタム XML 部分の詳細については、「カスタム XML 部分の概要」を参照してください。
データ アイランドとカスタム XML 部分の主な相違点と類似点を次の表に示します。
データ キャッシュ |
カスタム XML 部分 |
|
---|---|---|
これらの機能を使用できる Office アプリケーション |
以下のアプリケーションのドキュメント レベルのカスタマイズ
|
以下のアプリケーションのドキュメント レベルのソリューションおよびアプリケーション レベルのソリューション
|
格納できるデータの種類 |
カスタマイズ アセンブリ内の特定の要件を満たすパブリック オブジェクト。詳細については、「キャッシュされたデータ」を参照してください。 |
XML データ |
Microsoft Office アプリケーションを起動することなくデータにアクセスできるかどうか |
Visual Studio Tools for Office ランタイムに含まれる ServerDocument クラスを使用してアクセスできます。 |
.NET Framework 3.0 で導入された System.IO.Packaging 名前空間のクラスを使用してアクセスできます。 |