- 热门文章:
- · ASP.NET中根据XML动态创建并使用WEB组件(三)
- · ASP.NET中根据XML动态创建并使用WEB组件(二)
- · ASP.NET中根据XML动态创建并使用WEB组件(一)
- · 开发基于Web的CSS设计器
- · 用ImessageFilter接口实现截获键盘消息
- · 窗体启动特效
- · Microsoft Visual Studio .NET 2003制作安装程序
- · 实现基于事件通知的.Net套接字
- · Programming MS Office 2000 Web Components第一章第三节
- · WalkThrough : SharePoint WebPart入门指南全5辑
- · .Net WinForm学习笔记
- · 在IE浏览器中使用Windows窗体控件(三)
上一篇:在ASP.NET中实现MVC模式(二) >>
在ASP.NET中实现MVC模式(一)
背景:
当利用ASP.NET创建Web应用程序时,基于程序的复杂性,必须把程序分割成不同的部分以减少代码的重复及减少日后变革时所引起的改动。
实现策略:
为了解释如何在ASP.NET中实现(MVC)模型-视图-控制器模式,以及说明将软件分离成模型、视图、及控制器角色的好处,在此以一个示例程序为例进行说明。这个示例程序是一个带有下拉框的单页程序,它的功能是显示数据库中的数据。如下图。
当用户在下拉框中选择了一个记录,并单击Submit按钮的时候,程序从数据库中搜索与选中记录相关的数据库记录,并以列表的形式显示出来。下面,将以三种不同的实现方式进行实现。
单页模式
在ASP.NET中有许多解决这个问题的办法,其中最简单也是最直接的办法就是把所有的代码都放到一个文件中,并起名为Solution.aspx,实现代码如下:
<%@ Import Namespace="System.Data" %>
<%@ Import Namespace="System.Data.SqlClient" %>
<html>
<head>
<title>start</title>
<script language="c#" runat="server">
void Page_Load(object sender, System.EventArgs e)
{
String selectCmd = "select * from Recording";
SqlConnection myConnection =
new SqlConnection(
"server=(local);database=recordings;Trusted_Connection=yes");
SqlDataAdapter myCommand = new SqlDataAdapter(selectCmd,
myConnection);
DataSet ds = new DataSet();
myCommand.Fill(ds, "Recording");
recordingSelect.DataSource = ds;
recordingSelect.DataTextField = "title";
recordingSelect.DataValueField = "id";
recordingSelect.DataBind();
}
void SubmitBtn_Click(Object sender, EventArgs e)
{
String selectCmd =
String.Format(
"select * from Track where recordingId = {0} order by id",
(string)recordingSelect.SelectedItem.Value);
SqlConnection myConnection =
new SqlConnection(
"server=(local);database=recordings;Trusted_Connection=yes");
SqlDataAdapter myCommand = new SqlDataAdapter(selectCmd,
myConnection);
DataSet ds = new DataSet();
myCommand.Fill(ds, "Track");
MyDataGrid.DataSource = ds;
MyDataGrid.DataBind();
}
</script>
</head>
<body>
<form id="start" method="post" runat="server">
<h3>Recordings</h3>
Select a Recording:<br />
<asp:dropdownlist id="recordingSelect" runat="server" />
<asp:button runat="server" text="Submit" OnClick="SubmitBtn_Click" />
<p/>
<asp:datagrid id="MyDataGrid" runat="server" width="700"
backcolor="#ccccff" bordercolor="black" showfooter="false"
cellpadding="3" cellspacing="0" font-name="Verdana"
font-size="8pt" headerstyle-backcolor="#aaaadd"
enableviewstate="false" />
</form>
</body>
</html>
这个实现文件包含了模型、视图、控制器这三种角色,但是没有将它们分割为不同的文件或类。其中的视图对象用HTML实现,用一个数据绑定控件来显示从数据库返回的DataSet中的数据。模型角色在Page_Load 和 SubmitBtn_Click函数中实现。而控制器角色并没有显式的实现,而是由ASP.NET隐式实现。程序运行时,当用户发出页面的请求,页面随着用户的选择更新。
下一篇:ASP.NET中根据XML动态创建并使用WEB组件(三) >>
相关文章:
- · 在IE浏览器中使用Windows窗体控件(二)
- · 在IE浏览器中使用Windows窗体控件(一)
- · 基于ASP.NET实现全球化
- · Asp.net动态生成html页面
- · 可以搜索的ComboBox----
- · 实战 .Net 数据访问层 - 5
- · 实战 .Net 数据访问层 - 4
- · 实战 .Net 数据访问层 - 3
- · 实战 .Net 数据访问层 - 2
- · .Net里的序列化
- · 从在 Internet Explorer 中使用 Windows 窗体控件开始谈Smart Client
- · 关于何种情况下使用DataGrid、DataList或Repeater的一些讨论(4)
- · 关于何种情况下使用DataGrid、DataList或Repeater的一些讨论(3)
- · 关于何种情况下使用DataGrid、DataList或Repeater的一些讨论(2)
- · 关于何种情况下使用DataGrid、DataList或Repeater的一些讨论(1)
- · Csharp+Asp.net系列教程(三)
- · Csharp+Asp.net系列教程(二)
- · 设计模式之代理模式(Proxy)
- · 弹出对话框的同时保持页面的显示
- · ASP.Net中使用VB.Net调用存储过程并得到返回值
- · 改变文本框、按钮样式函数
- · 使用Asp.Net中的XmlValidatingReader来验证XML Schema.
- · 用asp.net 实现“九连环” 小游戏
- · ASP.Net中使用VB.Net调用存储过程并得到返回值
- · ASP.NET 的亲密朋友之--javascript
- · 如何开发一个可复用的软件系统
- · 在ASP.NET中显示进度条
- · 路由模拟——类设计的声明部分
- · 如何重新设置DataSet中的DataTable对象
- · 用NUnit2.1简单实现.net的测试驱动开发(TDD)
- · ASP.NET中的STREAMREADER对象总结
- · ASP.NET中的STREAMREADER对象总结
- · ASP.NET中的FILESTREAM对象总结
- · ASP.NET中的FILE对象总结
- · asp.net中常用的一些小技巧
- · DataGrid删除确认及Item颜色交替
- · asp.net生成缩略图
- · 设计模式之单件模式(Singleton Pattern )
