• <label id="pxtpz"><meter id="pxtpz"></meter></label>
      1. <span id="pxtpz"><optgroup id="pxtpz"></optgroup></span>

        當前位置:雨林木風下載站 > 技術開發教程 > 詳細頁面

        在ASP.NET中完成MVC模式(一)

        在ASP.NET中完成MVC模式(一)

        更新時間:2022-05-14 文章作者:未知 信息來源:網絡 閱讀次數:

        在ASP.NET中實現Model-View-Controller模式(一)



        背景:



        當利用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隱式實現。程序運行時,當用戶發出頁面的請求,頁面隨著用戶的

        溫馨提示:喜歡本站的話,請收藏一下本站!

        本類教程下載

        系統下載排行

        主站蜘蛛池模板: 亚洲国产精品无码第一区二区三区| 免费一级毛片一级毛片aa| 日韩亚洲变态另类中文| 亚洲av片在线观看| 国内大片在线免费看| 亚洲国产成人99精品激情在线| 国产成人精品免费视频网页大全| 无码乱人伦一区二区亚洲一| 久久久精品免费国产四虎| 亚洲AV无码久久寂寞少妇| 暖暖免费日本在线中文| 亚洲宅男永久在线| 毛片免费全部播放无码| 亚洲av专区无码观看精品天堂| 免费大片黄在线观看yw| 国产成人亚洲综合网站不卡| 精品久久久久久久免费人妻| 亚洲AV成人无码网天堂| 亚洲国产精品成人久久蜜臀 | 成人免费大片免费观看网站| 亚洲视频免费在线播放| 91免费资源网站入口| 亚洲精品V天堂中文字幕| 亚洲精品NV久久久久久久久久| 一区二区三区视频免费观看| 亚洲精品自产拍在线观看| 污污网站免费观看| 亚洲日韩AV一区二区三区中文| 免费一级做a爰片久久毛片潮喷| 成人A毛片免费观看网站| 久久久久亚洲精品天堂| 成年女人免费视频播放体验区| 最新亚洲人成无码网站| 亚洲国产精品一区二区第一页 | 成人在线视频免费| 又硬又粗又长又爽免费看 | 亚洲暴爽av人人爽日日碰| 亚洲综合图色40p| 69天堂人成无码麻豆免费视频| 亚洲丶国产丶欧美一区二区三区| 亚洲色婷婷综合开心网|