日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > c/c++ >内容正文

c/c++

Asp.net MVC3.0 入门指南 7.1 展示查找页面

發布時間:2025/5/22 c/c++ 30 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Asp.net MVC3.0 入门指南 7.1 展示查找页面 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

添加一個查找方法和查找視圖

在這一節我們將實現一個SearchIndex響應方法,允許您按流派或名字查找電影。

它利用網址/Movies/SearchIndex。請求將展示一個HTML頁面,它包含為了查

找電影由用戶輸入的input控件。當用戶提交頁面時,響應方法將獲得由用戶post

的查找條件并依據條件查詢數據庫。最終的效果圖如下所示 。

?

展示查找頁面

首先,在MoviesController類中添加一個SearchIndex響應方法。這個方法返回一個包含HTML

頁面的視圖。代碼如下:

public ActionResult SearchIndex(string searchString) {var movies = from m in db.Moviesselect m;if (!String.IsNullOrEmpty(searchString)) {movies = movies.Where(s => s.Title.Contains(searchString));}return View(movies); } ?

SearchIndex方法的第一行創建了以下的LINQ查詢來查詢電影:

var movies = from m in db.Moviesselect m; ?

查詢在這里定義,但卻沒有執行!(譯注:LINQ在需要執行的時候才會執行。

一般來說,真正需要使用數據時才真正執行)

如果參數searchString不是空字符串,電影的查詢被修改為過濾查找字符串,

使用如下代碼:

??

if (!String.IsNullOrEmpty(searchString)) {movies = movies.Where(s => s.Title.Contains(searchString)); }

當定義或通過Where、OrderBy方法修改時,LINQ查詢并沒有執行。相反,

查詢的執行被延遲,這意味著LINQ表達式一直被延遲到它真實的值被遍歷

(循環)或被ToList方法調用。在SearchIndex方法中,LINQ查詢在SearchIndex

視圖中執行。了解更多關于延遲查詢執行,參見Query Execution。

現在您可以實現SearchIndex視圖展示給用戶。右鍵SearchIndex方法內部并單擊

“Add View”,在“Add View”對話框中,指明您將傳遞Movie對象給視圖模板

作為它的模型類。在架構模板(Scaffold template)列表中,選擇List,單擊Add

當您單擊Add按鈕時,視圖模板Views\Movies\SearchIndex.cshtml被創建。

因為您在架構模板(Scaffold template)選擇List,Visual Studio自動在視
圖中生成了一些內容。架構創建了一個HTML窗體。它檢查Movie類并為每個

類屬性創建代碼來輸出<label>元素。下面展示了自動生成的創建視圖:

?

@model IEnumerable<MvcMovie.Models.Movie>@{ ViewBag.Title = "SearchIndex"; }<h2>SearchIndex</h2><p>@Html.ActionLink("Create New", "Create") </p> <table><tr><th>Title</th><th>ReleaseDate</th><th>Genre</th><th>Price</th><th></th></tr>@foreach (var item in Model) {<tr><td>@Html.DisplayFor(modelItem => item.Title)</td><td>@Html.DisplayFor(modelItem => item.ReleaseDate)</td><td>@Html.DisplayFor(modelItem => item.Genre)</td><td>@Html.DisplayFor(modelItem => item.Price)</td><td>@Html.ActionLink("Edit", "Edit", new { id=item.ID }) |@Html.ActionLink("Details", "Details", new { id=item.ID }) |@Html.ActionLink("Delete", "Delete", new { id=item.ID })</td></tr> }</table>

運行程序,并導航到/Movies/SearchIndex。給URL追加一個查詢字符串,比如

?searchString=ghost。篩選后的電影顯示如下。

如果您改變SearchIndex方法的簽名,改為一個名叫id的參數,id參數會匹配默認路由{id}占位符

集合(在Global.asax文件中)。

{controller}/{action}/{id}

修改后的SearchIndex方法看起來如下所示:

??

public ActionResult SearchIndex(string id) {string searchString = id;var movies = from m in db.Moviesselect m;if (!String.IsNullOrEmpty(searchString)) {movies = movies.Where(s => s.Title.Contains(searchString));}return View(movies); }

?

? 您現在可以使用路由數據(一個URL片段)來傳遞查找標題,而不是作為一個查詢字符串了。

(譯注:注意和上一個張圖比較,看看URL發生了什么變化!)

但是,您不能期望用戶每次查找電影都來修改URL!所以現在您需要添加UI來幫助他們篩選電影。

如果您改變SearchIndex的簽名來測試如何傳遞路由綁定參數ID,把它改回原樣。(譯注:剛才

只是為了說明默認路由的作用)

?

public ActionResult SearchIndex(string searchString) {var movies = from m in db.Moviesselect m;if (!String.IsNullOrEmpty(searchString)) {movies = movies.Where(s => s.Title.Contains(searchString));}return View(movies); } ?

打開文件Views\Movies\SearchIndex.cshtml,

并在后@Html.ActionLink("Create New", "Create"),添加如下代碼:

?

@using (Html.BeginForm()) { <p>Title: @Html.TextBox("SearchString")<input type="submit" value="Filter" /></p> }

?

下面的例子展示了Views\Movies\SearchIndex.cshtml文件的一部分被添加的過濾

標記。

?

@model IEnumerable<MvcMovie.Models.Movie> @{ ViewBag.Title = "SearchIndex"; } <h2>SearchIndex</h2> <p>@Html.ActionLink("Create New", "Create")@using (Html.BeginForm()) { <p>Title: @Html.TextBox("SearchString")<br /><input type="submit" value="Filter" /></p> } </p>

?

Html.BeginForm助手創建了一個開放的<form>標簽。Html.BeginForm助手

使得當用戶單擊Filter按鈕時頁面提交form給自己。

運行程序并試著查找電影。

?

未完待續。。。

原文網址:http://www.asp.net/mvc/tutorials/getting-started-with-mvc3-part6-cs

轉載于:https://www.cnblogs.com/BingoLee/archive/2011/06/28/2092060.html

總結

以上是生活随笔為你收集整理的Asp.net MVC3.0 入门指南 7.1 展示查找页面的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。