日期:2010-08-04  浏览次数:20606 次

  一、 简介

  本文将向你展示如何使用微软新的Web开发技术(代码名为Atlas)来实现数据绑定和模板。如果你已经理解什么是Atlas,其主要设计目的及其主要组件,那么你在阅读本文时将最大程度地受益。

  本文将向你展示:

  · 把一个客户端listView控件绑定到一个dataSource控件。

  · 使用模板显示数据。

  前提

  为了完成本文中的示例程序,你需要具备下列条件:

  · Microsoft Visual Studio 2005和.NET Framework 2.0。有关下载信息,请访问.NET Framework Developer Center Web站点。

  · 要把Atlas包安装到你的计算机上。这个MSI安装器文件包括一个Visual Studio Content Installer(.vsi)以便在Visual Studio中创建一个空白的Atlas Web应用程序。在本文中,我们省略了如何安装ASP.NET Atlas内容。

  二、 创建Atlas应用程序

  首先,你要在Visual Studio中创建一个Atlas Web应用程序。当你使用Visual Studio工程模板来创建一个新的空白Atlas Web应用程序时,Visual Studio会创建一个正常的具有下列一些其它项的Web站点文件夹结构:

  · 一个名为Microsoft.Web.Atlas.dll的可执行文件,它驻留在Bin文件夹下以提供服务器端功能。

  · 一个文件Web.config,用于设置Atlas应用程序。

  在Visual Studio中创建一个新的Atlas Web应用程序

  1. 在"File"菜单下,点击"New",然后点击"Web Site"。

  2. 在"New Web Site"对话框中,选择"ASP.NET Atlas Web Site"模板项。

  3. 在"Location"列表中,选择"File System"。

  4. 指定程序的一个路径和开发语言,然后点击"OK"。

  三、 提供应用程序测试数据

  在这一部分中,你要创建数据绑定程序所要使用的两项内容:

  · 一个数据源对象-它通过提供一些测试数据和类SQL语句来模拟一个数据库。

  · 一个Web服务-它连接到数据源对象并且把该数据提供给一个使用Atlas组件创建的UI。

  首先,你要创建数据源对象。

  创建数据源对象

  1. 在解决方案资源管理器中,右击站点名字,然后点击"Add New Item"。

  2. 在"Add New Item"对话框中,选择"Class",并且命名这个类为SampleRow(没有文件扩展名)。

  3. 为该类选择开发语言,然后点击"Add"按钮。

  4. 当系统提问你,是否你想把这个类文件放到App_Code文件夹下时,点击"Yes"。

  5. 在编辑器中,从已有类中删除任何现有代码。

  6. 把下列代码粘贴到这个类中以创建一个数据源对象。

using System;
using System.Collections;
using System.ComponentModel;
public class SampleRow{
private string _name;
private string _description;
private int _id;
[DataObjectField(true, true)]
public int Id
{
get { return _id; }
set { _id = value; }
}
[DataObjectField(false)]
[DefaultValue("New row")]
public string Name
{
get { return _name; }
set { _name = value; }
}
[DataObjectField(false)]
[DefaultValue("")]
public string Description
{
get { return _description; }
set { _description = value; }
}
public SampleRow()
{
_id = -1;
}
public SampleRow(int id, string name, string description)
{
_id = id;
_name = name;
_description = description;
}
}

  7. 保存并关闭文件。

  下一步是创建一个Web服务,由该服务为ASP.NET Web页面提供来自于数据源对象的数据。

  创建Web服务为页面提供数据

  1. 在解决方案资源管理器中,右击站点名字,然后点击"Add New Item"。

  2. 在"Add New Item"对话框中,在Visual Studio已安装的模板下,选择"Web Service"。

  3. 指定文件名为DataService.asmx并且不点选"Place code in separate file"复选框。

  4. 选择你想使用的语言。

  5. 点击"Add"。

  6. 在编辑器中,从现有类中删除任何现有代码。

  7. 把下列代码粘贴到这个类中以创建一个数据源对象。

<%@ WebService Language="C#" Class="SampleDataService" %>
using System;
using System.Collections;
using System.Collections.Generic;
using System.ComponentModel;
using System.IO;
using System.Web;
using System.Web.Caching;
using System.Web.Services;
using System.Web.Services.Protocols;
using Microsoft.Web.Services;
[WebService(Namespace = "http://tempuri.org/")]
[WebServiceBinding(ConformsTo = WsiProfiles.BasicProfile1_1)]
public class SampleDataService : DataService {
static List<SampleRow> _data;
static int _nextId;
static object _dataLock = new object();
private static List<SampleRow> Data {
 get {
  if (_data == null) {
   lock (_dataLock) {
    if (_data == null) {
     _data = new List<SampleRow>();
      _data.Add(new SampleRow(0, "A. Datum Corporation", "http://www.adatum.com"));
      _data.Add(new SampleRow(1, "Adventure Works", "http://www.adventure-works.com"));
      _data.Add(new SampleRow(2, "Alpine Ski House", "http://www.alpineskihouse.com"));
      _data.Add(new SampleRow(3, "Baldwin Museum of Science?", "htt