本专题介绍一个ASP.NET动态数据的网站的布局,其中包括这些文件默认情况下创建相关文件夹和文件。
vs.net 2008 + sp1
Dynamic Data Wizard 080608(http://www.codeplex.com/aspnet)
提供一个向导方式创建一个Dynamic Data Web Site
知识点:
LINQ-TO-SQL,Ado.net framework entity
System.Web.Routing
图表 1
图表 2
图表 3
下表介绍了在ASP.NET动态数据网站在根目录级创建的文件和文件夹。
文件和文件夹 |
描述 |
DynamicData |
包含显示和操作数据的页面和自定义控件,页面,和子控件如字段控件 |
Default.aspx |
一个默认首页面显示所有注册的数据模型及表名。通过一个超链接,显示选择表的内容。 |
Global.asax |
包含一个 注册数据库实例元模型的方法,并新增一个RouteCollection对象 |
Site.css |
站点和控件的显示风格 |
Site.master |
站点模板 |
web.config |
配置文件,加载必要的类库 |
Web.Config
图表 4
图表 5
public static void RegisterRoutes(RouteCollection routes) {
MetaModel model = new MetaModel();
//model.RegisterContext(typeof(YourDataContextType), new ContextConfiguration() { ScaffoldAllTables = false });
routes.Add(new DynamicDataRoute("{table}/{action}.aspx") {
Constraints = new RouteValueDictionary(new { action = "List|Details|Edit|Insert" }),
Model = model
});
//routes.Add(new DynamicDataRoute("{table}/ListDetails.aspx") {
// Action = PageAction.List,
// ViewName = "ListDetails",
// Model = model
//});
//routes.Add(new DynamicDataRoute("{table}/ListDetails.aspx") {
// Action = PageAction.Details,
// ViewName = "ListDetails",
// Model = model
//});
}
将创建的LINQ-TO-SQL注册到MetaModel中
model.RegisterContext(typeof(NorhwindDbDataContext), new ContextConfiguration() { ScaffoldAllTables = true });
图表 6
首页的代码片断,显示所有注册的表
protected void Page_Load(object sender, EventArgs e)
{
System.Collections.IList visibleTables = MetaModel.Default.VisibleTables;
if (visibleTables.Count == 0)
{
throw new InvalidOperationException("There are no accessible tables. Make sure that at least one data model is registered in Global.asax and scaffolding is enabled or implement custom pages.");
}
Menu1.DataSource = visibleTables;
Menu1.DataBind();
}
图表 7
各个页面中的超链接通过RouteCollection(System.Web.Routing)的路由规则进行页面间的跳转和对数据新增/修改/删除操作;关于System.Web.Routing在asp.net mvc中有比较详细的介绍
routes.Add(new DynamicDataRoute("{table}/{action}.aspx") {
Constraints = new RouteValueDictionary(new { action = "List|Details|Edit|Insert" }),
Model = model
});
下期讲如何通过Routing的规则控制表的修改,新增操作页面;