ASP.NET MVC 学习4、Controller中添加SearchIndex页面,实现简单的查询功能

时间:2022-09-07 09:33:32

参考:http://www.asp.net/mvc/tutorials/mvc-4/getting-started-with-aspnet-mvc4/examining-the-edit-methods-and-edit-view

本文内容:

1,熟悉MVC的路由过程,URL如果导向到Controller相应的方法中

2,新增SearchIndex页面,实现简单的查询功能

http://localhost:9898/Movies,鼠标移动到”Edit”上面的时候,我们看到Edit将要导向的路径:

ASP.NET MVC 学习4、Controller中添加SearchIndex页面,实现简单的查询功能

这个路径对应的HTML代码是: @Html.ActionLink("Edit", "Edit", new { id = item.ID })

参数说明:第一个参数linkText链接文字,第二个参数是需要调用的action 方法,第三个参数是匿名对象(anonymous object)生成路由数据:

ASP.NET MVC 学习4、Controller中添加SearchIndex页面,实现简单的查询功能

HTML对象的ActionLink method 动态生成(dynamically genetate)HTML链接指向Controller中的 action methods.

http://localhost:9898/movies/Edit/1 这个url路径,asp.net会根据MVC中默认的路由配置(App_Start\RouteConfig.cs)按照{controller}/{action}/{id}的格式进行导向:{movies}/{Edit}/{1}    默认路由配置:

ASP.NET MVC 学习4、Controller中添加SearchIndex页面,实现简单的查询功能ASP.NET MVC 学习4、Controller中添加SearchIndex页面,实现简单的查询功能
public class RouteConfig
{
public static void RegisterRoutes(RouteCollection routes)
{
routes.IgnoreRoute("{resource}.axd/{*pathInfo}");
routes.MapRoute(
name: "Default",
url: "{controller}/{action}/{id}",
defaults: new { controller = "Home", action = "Index", id = UrlParameter.Optional }
);
}
}

如果我们更新URL:http://localhost:9898/Movies/Edit?ID=1 这个URL同样可以根据ActionResult方法导向到刚才的Edit页面,然后查看Controller中的Edit方法:

ASP.NET MVC 学习4、Controller中添加SearchIndex页面,实现简单的查询功能ASP.NET MVC 学习4、Controller中添加SearchIndex页面,实现简单的查询功能
 //点击"Edit"时会调用下面的这个Edit方法,传递过来ID,返回对应的Movie
//默认的ID参数为0
public ActionResult Edit(int id = 0)
{
Movie movie = db.Movies.Find(id);
if (movie == null)
{
return HttpNotFound();
}
return View(movie);
}
//
// POST: /Movies/Edit/5
//点击"Save"按钮,处理页面的post请求
[HttpPost]
public ActionResult Edit(Movie movie)
{
//
if (ModelState.IsValid)
{
db.Entry(movie).State = EntityState.Modified;
db.SaveChanges();
return RedirectToAction("Index");
}
return View(movie);
}

我们注意到ActionResult 方法上面有[HttpPost],这个HttpPost的意思是:只有页面的Post请求会调用这个方法。如果方法前面没有加[HttpPost],默认为[HttpGet]表示方法在Get请求的时候被调用

这里补一下GetPost方法:

1. get是从服务器上获取数据,post是向服务器传送数据。
2. get是把参数数据队列加到提交表单的ACTION属性所指的URL中,值和表单内各个字段一一对应,在URL中可以看到。post是通过HTTP post机制,将表单内各个字段与其内容放置在HTML HEADER内一起传送到ACTION属性所指的URL地址。用户看不到这个过程。
3. 对于get方式,服务器端用Request.QueryString获取变量的值,对于post方式,服务器端用Request.Form获取提交的数据。
4. get传送的数据量较小,不能大于2KB。post传送的数据量较大,一般被默认为不受限制。但理论上,IIS4中最大量为80KB,IIS5中为100KB。
5. get安全性非常低,post安全性较高。但是执行效率却比Post方法好。
建议:
1、get方式的安全性较Post方式要差些,包含机密信息的话,建议用Post数据提交方式;
2、在做数据查询时,建议用Get方式;而在做数据添加、修改或删除时,建议用Post方式

ActionRestlt方法对应的.cshtml页面中@model MvcMovie.Models.Movie 指明view template中的Model是 Movie。我们来看一下几个View中的Helper方法:

Html.LabelFor  helper显示了字段名称("Title", "ReleaseDate", "Genre", or "Price").

Html.EditorFor helper 加载了HTML <input>元素

Html.ValidationMessageFor helper显示其对应属性的验证信息

ASP.NET MVC 学习4、Controller中添加SearchIndex页面,实现简单的查询功能

点击”Save”时,<input> submit会提交一条post数据到 /Movies/Edit URL ,form中的数据传递到Server

处理POST请求:

  //点击"Save"按钮,处理页面的post请求
[HttpPost]
public ActionResult Edit(Movie movie)
{
//
if (ModelState.IsValid)
{
db.Entry(movie).State = EntityState.Modified;
db.SaveChanges();
return RedirectToAction("Index");
}
return View(movie);
}

ASP.NET MVC model binder接收页面提交的form数据并把数据新建为Movie 对象,作为ActionResult Edit(Movie movie)的参数。

ModelState.IsValid 方法,会检查提交过来的数据是否可以进行edit or update,如果数据是有效的,movies数据就会保存到MovieDBContext的实例中(db)。 MovieDBContext SaveChanges方法把数据保存到数据库。保存以后页面重定向到index页面

如果保存的数据是无效的,不符合规则的,Html.ValidationMessageFor 提示错误信息

Note:为了支持非英文地区在Decimal数字中输入逗号”," ,Edit.cshtml 添加以下js :  globalize JS下载

ASP.NET MVC 学习4、Controller中添加SearchIndex页面,实现简单的查询功能ASP.NET MVC 学习4、Controller中添加SearchIndex页面,实现简单的查询功能
@section Scripts {
@Scripts.Render("~/bundles/jqueryval")
<script src="~/Scripts/globalize.js"></script>
<script src="~/Scripts/globalize.culture.fr-FR.js"></script>
<script>
$.validator.methods.number = function (value, element) {
return this.optional(element) ||
!isNaN(Globalize.parseFloat(value));
}
$(document).ready(function () {
Globalize.culture('fr-FR');
});
</script>
<script>
jQuery.extend(jQuery.validator.methods, {
range: function (value, element, param) {
//Use the Globalization plugin to parse the value
var val = $.global.parseFloat(value);
return this.optional(element) || (
val >= param[0] && val <= param[1]);
}
});
</script>

webconfig中添加:

ASP.NET MVC 学习4、Controller中添加SearchIndex页面,实现简单的查询功能ASP.NET MVC 学习4、Controller中添加SearchIndex页面,实现简单的查询功能
<system.web>
<globalization culture ="en-US" />
<!--elements removed for clarity-->
</system.web>

所有的HttpGet方法都是类似的。他们得到一个Movie对象,然后传递给View,Get:不应该改变页面中的数据

下面我们添加查询页面 ,Adding a Search Method and Search View

1,Controller中添加SearchIndex方法():

  public ActionResult SearchIndex(string MovieGenre, string SearchString)
{
var GenreLst = new List<string>();
//Select All Genre
var GenreQry = from d in db.Movies
orderby d.Genre
select d.Genre;
GenreLst.AddRange(GenreQry.Distinct());
ViewBag.MovieGenre = new SelectList(GenreLst); // 把List传递给ViewBag
var movies = from m in db.Movies
select m;
//SearchString 字符串如果不为空,Movies filter 包含SearchString的对象
if (!string.IsNullOrEmpty(SearchString))
{
movies = movies.Where(s => s.Title.Contains(SearchString));
}
if (string.IsNullOrEmpty(MovieGenre))
//如果MovieGenre为空,直接返回movies
return View(movies);
else
{
//Movie不为空,filter Genre
return View(movies.Where(x => x.Genre == MovieGenre));
}
}

2,SearchIndex方法中右键点击,添加视图

ASP.NET MVC 学习4、Controller中添加SearchIndex页面,实现简单的查询功能

3,SearchIndex.cshtml页面中添加以下代码:

  @Html.ActionLink("Create New", "Create")
@using (Html.BeginForm("SearchIndex", "Movies", FormMethod.Get))
{
<p>
Genre: @Html.DropDownList("movieGenre", "All")
Title: @Html.TextBox("SearchString")
<input type="submit" value="Filter" />
</p>
}

4,查询页面实现:
ASP.NET MVC 学习4、Controller中添加SearchIndex页面,实现简单的查询功能

查询页面的,需要熟悉的东西:Linq语句查询,参数传递,View中HTML Helper中TextBoxt,DropDownList等控件的书写

ASP.NET MVC 学习4、Controller中添加SearchIndex页面,实现简单的查询功能的更多相关文章

  1. 【转】ASP&period;NET MVC学习笔记-Controller的ActionResult

    1. 返回ViewResult public ActionResult Index()   {       ViewData["Message"] = "Welcome ...

  2. ASP&period;NET MVC学习---(八)三个比较常用的方便的功能

    通过之前的了解 现在我们已经可以使用mvc进行一些简单的开发 但是还不够 哪里不够呢? 为什么现在的程序员喜欢用mvc进行开发 不就是因为它爽吗? 之前介绍的那些特点仅仅是mvc框架的一小部分 只是一 ...

  3. ASP&period;NET MVC 学习笔记-7&period;自定义配置信息 ASP&period;NET MVC 学习笔记-6&period;异步控制器 ASP&period;NET MVC 学习笔记-5&period;Controller与View的数据传递 ASP&period;NET MVC 学习笔记-4&period;ASP&period;NET MVC中Ajax的应用 ASP&period;NET MVC 学习笔记-3&period;面向对象设计原则

    ASP.NET MVC 学习笔记-7.自定义配置信息   ASP.NET程序中的web.config文件中,在appSettings这个配置节中能够保存一些配置,比如, 1 <appSettin ...

  4. ASP&period;NET MVC学习之模型验证篇

    一.学习前的一句话 在这里要先感谢那些能够点开我随笔的博友们.慢慢的已经在博客园中度过一年半了,伊始只是将博客园作为自己学习的记录本一样使用,也不敢将自己的随笔发表到博客园首页,生怕自己的技艺不高,反 ...

  5. ASP&period;NET MVC学习之控制器篇

    一.前言 许久之后终于可以继续我的ASP.NET MVC连载了,之前我们全面的讲述了路由相关的知识,下面我们将开始控制器和动作的讲解. ASP.NET MVC学习之路由篇幅(1) ASP.NET MV ...

  6. ASP&period;NET MVC学习系列&lpar;二&rpar;-WebAPI请求

    继续接着上文 ASP.NET MVC学习系列(一)-WebAPI初探 来看看对于一般前台页面发起的get和post请求,我们在Web API中要如何来处理. 这里我使用Jquery 来发起异步请求实现 ...

  7. ASP&period;NET MVC学习系列&lpar;二&rpar;-WebAPI请求&lpar;转&rpar;

    转自:http://www.cnblogs.com/babycool/p/3922738.html 继续接着上文 ASP.NET MVC学习系列(一)-WebAPI初探 来看看对于一般前台页面发起的g ...

  8. ASP&period;NET MVC学习之控制器篇&lpar;二&rpar;

    原文链接:http://www.asp.net/learn/mvc/ 这篇教程探索了ASP.NET MVC控制器(controller).控制器动作(controller action)和动作结果(a ...

  9. (转)ASP&period;NET MVC 学习第一天

    天道酬勤0322   博客园 | 首页 | 发新随笔 | 发新文章 | 联系 | 订阅  | 管理 随笔:10 文章:0 评论:9 引用:0 ASP.NET MVC 学习第一天 今天开始第一天学习as ...

随机推荐

  1. ngix代理-- 摘抄

    有两个网站,http://192.168.1.3:80和http://192.168.1.3:81, 通过nginx的配置实现只用本机作为唯一的代理服务器,只用一个端口, 实现这样的效果:请求http ...

  2. HttpModule的一些初步认识

    新建一个类 ValidaterHttpModuleEvents继承管道接口 IHttpModule,代码如下 public class ValidaterHttpModuleEvents:IHttpM ...

  3. Expectation maximization - EM算法学习总结

    原创博客,转载请注明出处 Leavingseason http://www.cnblogs.com/sylvanas2012/p/5053798.html EM框架是一种求解最大似然概率估计的方法.往 ...

  4. 查找所有含有表名(abc)的存储过程 执行脚本

    SELECT obj.Name , sc.TEXT FROM syscomments sc INNER JOIN sysobjects obj ON sc.Id = obj.ID WHERE sc.T ...

  5. 【M23】考虑使用其他程序库

    1.程序库的设计是一种权衡的结果.体积小,速度快往往不能移植.可移植,通用的程序库往往意味着冗余和效率低下. 2.因此,选择程序库的时候,需要进行取舍.比如:iostream和stdio.iostre ...

  6. &lbrack;Audio processing&rsqb; 常见语音特征 —— LPC

    共振峰产生的原理及其在音质上的体现,共振峰的分布位置是建立在声音产生媒介的共鸣物理结构基础上的(Resonant Physical Structure).   无论是人声还是乐器,它们的声音特性都源自 ...

  7. Micropython TPYBoard 智能温控小风扇资料分享

    南方都下大雪了,苦逼的北方还没下雪,天寒地冻,不过这几天办公室空调开太大了就想到做一个温控小风扇,简单模型出来了.等夏天一定做一个美观精致的小风扇送给女朋友(如果有的话QAQ)话不多说直接上干货.(跪 ...

  8. asp&period;net core 2&period;1 配置管理

    1. 直接读取配置 StartUp类中使用 Configuration["ConnectionString"], Configuration["AliyunAkSk:Ak ...

  9. Windows的cmd窗口显示utf8字符

    用XeLaTeX的时候,查字体需要用fc-list命令,XeLaTeX用的都是utf编码,所以fc-list输出的字体信息也是utf编码.因此需要把cmd窗口也改成utf8编码才能看到这些字体信息.U ...

  10. Unity Shader 学习之旅之SurfaceShader

    Unity Shader 学习之旅之SurfaceShader unity shader 图形图像  如果大地的每个角落都充满了光明 谁还需要星星,谁还会 在夜里凝望 寻找遥远的安慰——江河 官方文档 ...