欧美性猛交XXXX免费看蜜桃,成人网18免费韩国,亚洲国产成人精品区综合,欧美日韩一区二区三区高清不卡,亚洲综合一区二区精品久久

打開(kāi)APP
userphoto
未登錄

開(kāi)通VIP,暢享免費電子書(shū)等14項超值服

開(kāi)通VIP
體驗Jasper (轉 思歸囈語(yǔ) )

 

在3月份的MVP峰會(huì )上,ASP.NET開(kāi)發(fā)團隊給我們示范了Jasper(好像那時(shí)還不是這名稱(chēng)),因為NDA的原因,我們無(wú)法透露細節。如今Jasper公開(kāi)推出了,讓我們來(lái)體驗一下Jasper。

1. 安裝所需軟件和建立數據庫

1) Visual Studio Orcas Beta 1。下載細節可見(jiàn):

http://msdn2.microsoft.com/en-us/vstudio/aa700831.aspx

2) SQL Server 2005 (Express)版本 Edition。SQL Server 2005 Express版可下載于

http://www.microsoft.com/downloads/details.aspx?familyid=220549b5-0b07-4448-8848-dcc397514b41&displaylang=en

3) Iron Python 1.1 (你也可以VB.NET 9)。 下載地址:

http://www.codeplex.com/IronPython/Release/ProjectReleases.aspx?ReleaseId=2573

4) Jasper CTP。下載地址:

http://www.microsoft.com/downloads/details.aspx?FamilyId=471BB3AC-B31A-49CD-A567-F2E286715C8F&displaylang=en

5) 運行 C:\Program Files\Microsoft Codename Jasper CTP\Samples\Create and Populate Northwind.cmd 來(lái)創(chuàng )建一個(gè)小的Northwind數據庫。

2.Jasper API由三個(gè)主要部分組成:

  1. DynamicContext是使用Jasper的起點(diǎn)。應用程序調用該類(lèi)的靜態(tài)方法CreateDynamicContext()創(chuàng )建一個(gè)動(dòng)態(tài)的上下文對象,該對象封裝了與數據庫交互所需的連接和狀態(tài)信息。該對象對從查詢(xún)返回的數據對象進(jìn)行變化跟蹤(change tracking)和身份確定(identity resolution),可以用來(lái)把所作的數據對象的變化保存到數據庫去。
  2. Query類(lèi)支持建立和發(fā)出查詢(xún)命令,命令可以用Entity SQL查詢(xún)語(yǔ)言或LINQ。
  3. 代表數據實(shí)體的數據類(lèi),支持讀取和改變屬性值,以及自定義的業(yè)務(wù)邏輯。數據類(lèi)是運行時(shí)動(dòng)態(tài)生成的,其名稱(chēng)和結構與數據庫的數據定義或指定的實(shí)體數據模型相符。 Jasper數據類(lèi)生成器使用約定來(lái)建立數據類(lèi)的名稱(chēng)和它們的屬性。對數據庫里的每個(gè)表,或實(shí)體數據模型中的每個(gè)實(shí)體集合,Jasper會(huì )生成一個(gè)類(lèi)。Jasper有個(gè)命名組件,可以把名稱(chēng)為復數的表名轉換成單數的類(lèi)名,譬如,對應Products表,Jasper會(huì )生成Product類(lèi)。對應數據表的每個(gè)字段,Jasper會(huì )在類(lèi)中生成一個(gè)對應的屬性。Jasper會(huì )根據數據表的外鍵-主鍵關(guān)系建立引用屬性。DynamicContext.CreateDynamicContext()返回的上下文對象對應每個(gè)表還含有一個(gè)類(lèi)型是Query的屬性,譬如,Categories屬性和Products屬性等。該上下文對象對數據庫中的每個(gè)存儲過(guò)程還會(huì )生成相應的方法。你可以在代碼中使用這些動(dòng)態(tài)生成的數據類(lèi),即使這些類(lèi)在你編寫(xiě)代碼時(shí)還不存在。在運行時(shí),延遲綁定機制會(huì )確定你對這些數據類(lèi)的引用。

3. 看一下其中的BuildingUI_Web例子

GridViewPage.aspx,其顯示是這樣的:

.aspx內容為:

<%@ 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>

后臺文件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

注意,在后臺.vb中只需要設置前臺數據源控件AutoDataSource的DynamicContext屬性。

Jasper在看到前臺的
<asp:GridView ID="Products" runat="server" AutoGenerateDeleteButton="True" AutoGenerateEditButton="True" AllowPaging="True">
</asp:GridView>

根據設置的ID="Products",Jasper會(huì )將AutoDataSource1.DynamicContext中的Products查詢(xún)屬性綁定到GridView上。注意上面的第一行記錄,Chai2,是在我點(diǎn)擊“Edit”按鈕編輯更新后的結果。

再看另一個(gè)主從關(guān)系的例子,MasterDetailsPage.aspx,

后臺MasterDetailsPage.aspx.vb內容跟GridViewPage.aspx.vb是一樣的,MasterDetailsPage.aspx 的內容是這樣的(除去了前面的一些類(lè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類(lèi)里的CategoryName屬性一樣,該控件就會(huì )綁定到對應的數據表上,同時(shí)顯示指定的屬性值。

如果控件名是<Name>_<NavigationPropertyName>的形式,Jasper 就會(huì )將其綁定到<Name>數據表對應的類(lèi)的引用屬性<NavigationPropertyName>之上。同時(shí),AutoDataSource控件會(huì )去尋找綁定到<Name>的另一個(gè)控件,用它作為這個(gè)關(guān)系導航的數據源。

默認的綁定機制也可以通過(guò)覆蓋AutoDataSource上的各個(gè)AutoBind()方法來(lái)實(shí)現。AutoBind()方法可以把任意查詢(xún)對象綁定到可數據綁定的控件上??蓴祿壎ǖ目丶瓤擅鞔_指定,也可以讓AutoDataSource控件自動(dòng)根據查詢(xún)的返回類(lèi)型來(lái)確定合適的控件。

本站僅提供存儲服務(wù),所有內容均由用戶(hù)發(fā)布,如發(fā)現有害或侵權內容,請點(diǎn)擊舉報。
打開(kāi)APP,閱讀全文并永久保存 查看更多類(lèi)似文章
猜你喜歡
類(lèi)似文章
ASP.NET內置對象
.net緩存技術(shù)詳解
什么是 ASP/ASP+/ASP.NET
ASP.NET編程中的十大技巧
ASP.NET頁(yè)面傳值的方法和一些實(shí)用技巧
ASP.NET Web應用程序修改頁(yè)面Inherits示例
更多類(lèi)似文章 >>
生活服務(wù)
分享 收藏 導長(cháng)圖 關(guān)注 下載文章
綁定賬號成功
后續可登錄賬號暢享VIP特權!
如果VIP功能使用有故障,
可點(diǎn)擊這里聯(lián)系客服!

聯(lián)系客服

欧美性猛交XXXX免费看蜜桃,成人网18免费韩国,亚洲国产成人精品区综合,欧美日韩一区二区三区高清不卡,亚洲综合一区二区精品久久