ASP.NET2.0+SQL Server2005构建多层应用第4/4页

 更新时间:2006年12月11日 00:00:00   作者:  

  创建表示层

  在ASP.NET 2.0中,在创建表示层时,可以使用master-page技术,使得可以很方便地构建页面。Mater-page的意思是,可以首先构建出一个页面的主框架模版结构,然后在其中放置一个ContentPlaceHolder控件,在该控件中,将展现其他子页面的内容。在其他子页面中,只需要首先引用该master页面,然后再修改ContentPlaceHolder控件的内容就可以了。

  首先,在工程中新增加一个"master"类型的文件,将其命名为CommonMaster,然后输入以下代码:


<%@ master language="C#" %>
<html>
 <head id="Head1" runat="server">
  <title>Master Page</title>
 </head>
<body>
<form id="Form1" runat="server">
 <table id="header" style="WIDTH: 100%; HEIGHT: 80px" cellspacing="1" cellpadding="1" border="1">
 <tr>
  <td style="TEXT-ALIGN: center; width: 100%; height: 74px;" bgcolor="teal">
   <asp:label runat="server" id="Header" Font-Size="12pt" Font-Bold="True">
     Authors Information
   </asp:label>
  </td>
 </tr>
 </table>
 <b/>
 <table id="leftNav" style="WIDTH: 108px; HEIGHT: 100%" cellspacing="1" cellpadding="1" border="1">
 <tr>
  <td style="WIDTH: 100px">
   <table>
    <tr>
     <td>
      <a href="Home.aspx">Home</a>
     </td>
    </tr>
    <tr>
     <td>
      <a href="Authors.aspx">Authors List</a>
     </td>
    </tr>
   </table>
  </td>
 </tr>
 </table>
 <table id="mainBody" style="LEFT: 120px; VERTICAL-ALIGN: top; WIDTH: 848px; POSITION: absolute; TOP: 94px; HEIGHT: 100%" border="1">
  <tr>
   <td width="100%" style="VERTICAL-ALIGN: top">
    <asp:contentplaceholder id="middleContent" runat="Server"></asp:contentplaceholder>
   </td>
  </tr>
 </table>
</form>
</body>
</html>



接下来,我们首先创建以显示作者页面的Authors.aspx页面,由于页面的框架要保持一直,因此,可以利用maser-page技术,在新建页面时,引入刚才建立的CommonMaster页面,如下图:



点ADD按钮后,出现如下图,选择刚才建立的CommonMaster页面,如下图:





再输入如下代码:


<%@ Page Language="C#" MasterPageFile="~/CommonMaster.master" %>
<asp:content id="Content1" contentplaceholderid="middleContent" runat="server">
<asp:objectdatasource runat="server" id="authorsSource" typename="Author*iz" selectmethod="GetAuthors">
</asp:objectdatasource>
<asp:gridview runat="server" AutoGenerateColumns="false" id="authorsView" datasourceid="authorsSource">
 <alternatingrowstyle backcolor="Silver"></alternatingrowstyle>
<Columns>
<asp:HyperLinkField DataTextField="au_id" HeaderText="Author ID" DataNavigateUrlFields="au_id"
DataNavigateUrlFormatString="AuthorTitles.aspx?AuthorID={0}">
</asp:HyperLinkField>
<asp:BoundField HeaderText="Last Name" DataField="au_lname"></asp:BoundField>
<asp:BoundField HeaderText="First Name" DataField="au_fname"></asp:BoundField>
<asp:BoundField HeaderText="Phone" DataField="phone"></asp:BoundField>
<asp:BoundField HeaderText="Address" DataField="address"></asp:BoundField>
<asp:BoundField HeaderText="City" DataField="city"></asp:BoundField>
<asp:BoundField HeaderText="State" DataField="state"></asp:BoundField>
<asp:BoundField HeaderText="Zip" DataField="zip"></asp:BoundField>

</Columns>
</asp:gridview>
</asp:content>


注意,其中我们用到了objectdatasource控件,在.NET 2.0中,有了该控件,可以很方便地沟通表示层和逻辑层。其中的代码如下:


<asp:objectdatasource runat="server" id="authorsSource" typename="Author*iz" selectmethod="GetAuthors">
</asp:objectdatasource>


  其中的typename属性指定为我们之前创建的逻辑层的类Author*iz类,而为了获得数据,采用了selectmethod方法,这里指定了之前建立的GetAuthors方法。当然,也可以在其他场合,应用Updatemethod,Insertmethod,Deletemethod方法,也可以加上参数,比如接下来要创建的AuthorTitle.aspx页面,代码如下:

<%@ Page Language="C#" MasterPageFile="~/CommonMaster.master" %>
<asp:content id="Content1" contentplaceholderid="middleContent" runat="server">
<asp:objectdatasource runat="server" id="authorTitlesSource" typename="Author*iz" selectmethod="GetAuthorTitles">
<SelectParameters>
 <asp:QueryStringParameter Type="String" Direction="Input" Name="authorID" QueryStringField="AuthorID" />
</SelectParameters>
</asp:objectdatasource>
<asp:gridview runat="server" id="authorTitlesView" datasourceid="authorTitlesSource">
 <alternatingrowstyle backcolor="Silver"></alternatingrowstyle>
</asp:gridview>
</asp:content>


  上面的代码中,首先用户在authors.aspx页面点选某个作者名时,则在authortitle.aspx页面中,返回该作者的所有著作。所以,在objectdatasource控件中,我们使用了SelectParameters参数,指定传入来要查询的参数是authorid。最后,再将gridview绑定到objectdatasource控件中去。

  最后,运行我们的代码,结果如下两图所表示:






小结

  在ASP.NET 2.0中,我们利用SQL Server 2005的强大功能,可以利用.NET 语言创建存储过程,并使用TableAdapter向导,很方便地创建数据访问层,再利用objectdatasource控件的特性,可以很方便地沟通表示层和逻辑层。 [/sell]

相关文章

  • ASP.NET中使用用户控件

    ASP.NET中使用用户控件

    这篇文章介绍了ASP.NET中使用用户控件的方法,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-05-05
  • WPF使用ValidationRules对MVVM架构数据验证

    WPF使用ValidationRules对MVVM架构数据验证

    这篇文章介绍了WPF使用ValidationRules对MVVM架构数据验证的方法,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-01-01
  • ASP.NET与数据库相关技巧

    ASP.NET与数据库相关技巧

    [红色]ASP.NET与数据库相关技巧...
    2006-10-10
  • ORM框架之Dapper简介和性能测试

    ORM框架之Dapper简介和性能测试

    这篇文章介绍了ORM框架之Dapper简介和性能测试,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-01-01
  • ASP.NET MVC项目部署方式介绍

    ASP.NET MVC项目部署方式介绍

    这篇文章介绍了ASP.NET MVC项目的部署方式,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-03-03
  • Entity Framework系统架构与原理介绍

    Entity Framework系统架构与原理介绍

    这篇文章介绍了Entity Framework系统架构与原理,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-03-03
  • WPF框架之Prism介绍

    WPF框架之Prism介绍

    这篇文章介绍了WPF的Prism框架,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-02-02
  • .NET 6新增的20个API介绍

    .NET 6新增的20个API介绍

    这篇文章介绍了.NET 6新增的20个API,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-12-12
  • .Net Core微服务rpc框架GRPC通信实际运用

    .Net Core微服务rpc框架GRPC通信实际运用

    这篇文章介绍了.Net Core微服务rpc框架GRPC通信实际运用,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-01-01
  • asp.net Timer的使用方法

    asp.net Timer的使用方法

    使用方法很简单,对于需要使用asp.net下timer控件的使用是个不错的例子
    2008-10-10

最新评论