在3月份的MVP峰會(huì)上,ASP.NET開發(fā)團(tuán)隊(duì)給我們示范了Jasper(好像那時(shí)還不是這名稱),因?yàn)镹DA的原因,我們無(wú)法透露細(xì)節(jié)。如今Jasper公開推出了,讓我們來體驗(yàn)一下Jasper。
1) Visual Studio Orcas Beta 1。下載細(xì)節(jié)可見:
http://msdn2.microsoft.com/en-us/vstudio/aa700831.aspx
2) SQL Server 2005 (Express)版本 Edition。SQL Server 2005 Express版可下載于
3) Iron Python 1.1 (你也可以VB.NET 9)。 下載地址:
http://www.codeplex.com/IronPython/Release/ProjectReleases.aspx?ReleaseId=2573
4) Jasper CTP。下載地址:
5) 運(yùn)行 C:\Program Files\Microsoft Codename Jasper CTP\Samples\Create and Populate Northwind.cmd 來創(chuàng)建一個(gè)小的Northwind數(shù)據(jù)庫(kù)。
GridViewPage.aspx,其顯示是這樣的:
.aspx內(nèi)容為:
<%@ Page Language="VB" AutoEventWireup="false" CodeFile="GridViewPage.aspx.vb"
Inherits="GridViewPage" %>
<%@ Register Assembly="Microsoft.Jasper.CTP" Namespace="Microsoft.Jasper.Web"
TagPrefix="jasper" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
<title>Demonstrate Building Web UI with Project Jasper using a GridView
control</title>
</head>
<body>
<form id="form1" runat="server">
<div>
<asp:Button ID="BackToMainButton" runat="server" Text="Back To Main"
PostBackUrl="Default.aspx" />
</div>
<asp:GridView ID="Products" runat="server"
AutoGenerateDeleteButton="True"
AutoGenerateEditButton="True" AllowPaging="True">
</asp:GridView>
<jasper:AutoDataSource ID="AutoDataSource1" runat="server">
</jasper:AutoDataSource>
</form>
</body>
</html>
后臺(tái)文件GridViewPage.aspx.vb,是這樣的(注釋被去除了):
Imports Microsoft.Jasper
Partial Class GridViewPage
Inherits System.Web.UI.Page
Protected Sub Page_Load(ByVal sender As Object, ByVal e As System.EventArgs) Handles Me.Load
AutoDataSource1.DynamicContext = GetDynamicContext()
End Sub
Private Function GetDynamicContext() As DynamicContext
Dim context As DynamicContext = Session("DynamicContext")
If context Is Nothing Then
Dim connectionString As String = ConfigurationManager.ConnectionStrings("Northwind").ConnectionString
context = DynamicContext.CreateDynamicContext(connectionString)
Session("DynamicContext") = context
End If
Return context
End Function
End Class
注意,在后臺(tái).vb中只需要設(shè)置前臺(tái)數(shù)據(jù)源控件AutoDataSource的DynamicContext屬性。
Jasper在看到前臺(tái)的
<asp:GridView ID="Products" runat="server" AutoGenerateDeleteButton="True" AutoGenerateEditButton="True" AllowPaging="True">
</asp:GridView>
根據(jù)設(shè)置的ID="Products",Jasper會(huì)將AutoDataSource1.DynamicContext中的Products查詢屬性綁定到GridView上。注意上面的第一行記錄,Chai2,是在我點(diǎn)擊“Edit”按鈕編輯更新后的結(jié)果。
再看另一個(gè)主從關(guān)系的例子,MasterDetailsPage.aspx,
后臺(tái)MasterDetailsPage.aspx.vb內(nèi)容跟GridViewPage.aspx.vb是一樣的,MasterDetailsPage.aspx 的內(nèi)容是這樣的(除去了前面的一些類似的聲明內(nèi)容):
<form id="form1" runat="server">
<asp:ListBox ID="CategoryName" runat="server" AutoPostBack="True"
Height="223px" Width="175px"></asp:ListBox>
<asp:GridView ID="Categories_Products" runat="server">
</asp:GridView>
<Jasper:AutoDataSource ID="AutoDataSource1" runat="server">
</Jasper:AutoDataSource>
</form>
在這里,Jasper會(huì)看到<asp:ListBox>的ID與動(dòng)態(tài)生成的Category類里的CategoryName屬性一樣,該控件就會(huì)綁定到對(duì)應(yīng)的數(shù)據(jù)表上,同時(shí)顯示指定的屬性值。
如果控件名是<Name>_<NavigationPropertyName>的形式,Jasper 就會(huì)將其綁定到<Name>數(shù)據(jù)表對(duì)應(yīng)的類的引用屬性<NavigationPropertyName>之上。同時(shí),AutoDataSource控件會(huì)去尋找綁定到<Name>的另一個(gè)控件,用它作為這個(gè)關(guān)系導(dǎo)航的數(shù)據(jù)源。
默認(rèn)的綁定機(jī)制也可以通過覆蓋AutoDataSource上的各個(gè)AutoBind()方法來實(shí)現(xiàn)。AutoBind()方法可以把任意查詢對(duì)象綁定到可數(shù)據(jù)綁定的控件上??蓴?shù)據(jù)綁定的控件既可明確指定,也可以讓AutoDataSource控件自動(dòng)根據(jù)查詢的返回類型來確定合適的控件。
聯(lián)系客服