ASP.NET MVC 入門7、Hellper與數據的提交與綁定

本系列文章基於ASP.NET MVC Preview5.
ASP.NET MVC提供了很多Hellper的方法,Hellper就是一些生成HTML代碼的方法,方便我們書寫HTML代碼(有一部分的朋友更喜歡直接寫HTML代碼)。我們也可以利用.NET 3.5的擴展方法來書寫我們自己的Hellper。
例如:
<%=Html.ActionLink("首頁","index","Home")%>
生成的HTML代碼就是:<a href="/Home/Index">首頁</a>。這裏有一點需要注意的就是,Html.ActionLink()和Url.Link()方法生成的URL和你在Global.asax裏面配置的Route的先後順序是有關的
具體的關於Hellper的各個方法的使用我就不詳細介紹了,你可以參考重典Asp.net Mvc Framework 系列文章。
我們來實現前面提到的Setting,用於設置Blog的基本設置。我們看一下在Views/Admin/Setting.aspx頁面的代碼:
複製代碼
<p>
    
<label for="Name">Blog的名稱</label>
    
<%=Html.TextBox("Name")%>
    
<%=Html.ValidationMessage("Name")%>
</p>
<p>
    
<label for="Description">Blog的簡單描述</label>
    
<%=Html.TextArea("Description")%>
    
<%=Html.ValidationMessage("Description")%>
</p>
<p>
    
<label for="PostsPerPage">每頁顯示的日誌數</label>
    
<%=Html.TextBox("PostsPerPage")%>
    
<%=Html.ValidationMessage("PostsPerPage")%>
</p> 
複製代碼
 
我們的Setting Action方法是這樣寫的:
p_w_picpath
注意我們是return View(BlogSettings.Instance);給ViewData.Model傳遞了BlogSettings.Instance。然後運行一下看看:
p_w_picpath
注意到上面的TextBox都有值了麼?我們使用了Html.TextBox("Name")而已,並沒有指定值啊?那麼這個值是怎麼自動的綁定上去的呢?注意到前面在Action中我們是return View(BlogSettings.Instance);給ViewData.Model傳遞了BlogSettings.Instance,BlogSettings.Instance.Name和Html.TextBox("Name")的參數"Name"同名,Html.TextBox()方法在調用的時候會調用ViewData.Eval()方法,所以就自動把值綁定上去了。和前一篇文章說過的ViewData.Eval()可以使用"."表達式一樣,Html.TextBox()也同樣可以使用"."表達式,例如:Html.TextBox("Post.Title")也可以自動綁定ViewData.Model.Post.Title值上去。
下面我們來將值提交到Action中並保存。我們的Form使用了Post回服務器:
<form id="fields" action="<%=Url.Action("Setting","Admin")%>" method="post">
 
然後我們在Action中進行處理:
複製代碼
[ActionName("Setting"), AcceptVerbs("POST")]
public ActionResult SaveSetting()
{
    
//當然你可以這樣取值
    
//string name = Request.Form["Name"]; 

    
//但我們有更簡便的:
    try
    {
        UpdateModel(BlogSettings.Instance, 
new[] { "Name""Description""PostsPerPage" });
    }
    
catch
    {
        
return View(BlogSettings.Instance);
    } 

    
//在這裏你可能還需要對自定義的業務邏輯進行驗證 

    BlogSettings.Instance.Save();
    
return ShowMsg(new List<string>() { "修改設置成功" });
複製代碼
如上代碼所示,我們可以使用UpdateModel()方法直接對Post到服務器來的Form表單的值賦給指定的對象。對於提交的數據進行業務邏輯的驗證這裏要討論的還是比較多的,國外也有不少文章討論這個的,大家可以搜索看看。
暫時就寫這麼多吧,想到什麼再補充。Enjoy!Post by Q.Lee.lulu
本文的Blog程序示例代碼:4mvcBlog_7.rar
---------------------------------------------------------------------
更多內容,請關注http://blog.51mvc.com/ 和 http://bbs.51mvc.com/
作者:QLeelulu Follow 
出處:http://QLeelulu.cnblogs.com/ 
本文版權歸作者和博客園共有,歡迎轉載,但未經作者同意必須保留此段聲明,且在文章頁面明顯位置給出原文連接,否則保留追究法律責任的權利
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章