mvc JavaScriptResult的用法
mvc JavaScriptResult的用法
mvc JavaScriptResult的用法一、JavaScriptResult在MVC中的定义的代码片段
public class JavaScriptResult : ActionResult
{
public override void ExecuteResult(ControllerContext context)
{
HttpResponseBase response = context.HttpContext.Response;
response.ContentType = "application/x-javascript";
response.Write(this.Script);
}
public string Script { get; set; }
}
public abstract class Controller : ControllerBase, ...
{
//其他成员
protected virtual JavaScriptResult JavaScript(string script);
}
其中:JavaScriptResult的属性Script表示响应的JavaScript脚本,而用于响应JavaScript脚本的ExecuteResult方法除了将脚本内容写入当前HttpResponse之外,还会将响应的媒体类型设置为“application/x-javascript”(不是“text/javascript”)。
二、可以通过ContentResult来实现与JavaScriptResult一样的脚本响应功能
例如下面两段代码效果一样
//JavaScriptResult:
public class FooController : Controller
{
public ActionResult JavaScript()
{
return JavaScript("alert('Hello World!');");
}
}
//ContentResult:
public class FooController : Controller
{
public ActionResult JavaScript()
{
return Content("alert('Hello World!');", "application/x-javascript");
}
}
三、JavaScriptResult实例
下面演示一个在线购物的场景:用于完成了商品选购之后提交订单,服务端在处理订单的时候需要确认订购的商品是否超出了对应的库存量,如果存量充裕则正常处理该订单,否则提示库存不足,并将商品实时库存量显示给用户让他修正相应商品的购买量。我们利用JavaScript的方式来提示订单处理结果的消息(成功处理或者库存不足),很显然这段JavaScript应该是动态的(库存量是动态的)。
1、定义一个ShoppingCart类表示购物车。如下面的代码片断所示,ShoppingCart是表示购物车商品项ShoppingCartItem对象的列表,而ShoppingCartItem的三个属性(Id、Name和Quantity)分别表示商品ID、名称和订购数量。
public class ShoppingCart : List<ShoppingCartItem>
{}
public class ShoppingCartItem
{
public string Id { get; set; }
public string Name { get; set; }
public int Quantity { get; set; }
}
2、创建如下一个HomeController。我们在默认的Action方法Index中创建一个包含三个商品的ShoppingCart对象,并将其作为Model呈现在对应的View中。Action方法ProcessOrder用于处理提交的购买订单,如果订购商品的数量没有超过库存量(通过一个静态字典字段stock表示),则通过调用alert函数提示“购物订单成功处理”,否则提示“库存不足”,并将相应商品当前库存量显示出来。
public class HomeController : Controller
{
private static Dictionary<string, int> stock = new Dictionary<string, int>();
static HomeController()
{
stock.Add("001", 20);
stock.Add("002", 30);
stock.Add("003", 40);
}
public ActionResult Index()
{
ShoppingCart cart = new ShoppingCart();
cart.Add(new ShoppingCartItem { Id = "001", Quantity=1, Name = "商品A" });
cart.Add(new ShoppingCartItem { Id = "002", Quantity = 1, Name = "商品B" });
cart.Add(new ShoppingCartItem { Id = "003", Quantity = 1, Name = "商品C" });
return View(cart);
}
public ActionResult ProcessOrder(ShoppingCart cart)
{
StringBuilder sb = new StringBuilder();
foreach (var cartItem in cart)
{
if (!CheckStock(cartItem.Id, cartItem.Quantity))
{
sb.Append(string.Format("{0}: {1};", cartItem.Name,stock[cartItem.Id]));
}
}
if(string.IsNullOrEmpty(sb.ToString()))
{
return Content("alert('购物订单成功处理!');", "text/javascript");
}
string script = string.Format("alert('库存不足! ({0})');", sb.ToString().TrimEnd(';'));
return JavaScript(script);
}
private bool CheckStock(string id, int quantity)
{
return stock[id] >= quantity;
}
}
3、创建Action方法Index对应的View。在一个以Ajax请求提交的表单(表单的Action属性对应着上面定义的Action方法ProcessOrder)中显示了购物车中的商品和数量,用于可以修改订购数量并通过点击“提交订单”按钮以Ajax请求的方式提交订单。
@model ShoppingCart
<html>
<head>
<title>用户登录</title>
<script type="text/javascript" src="@Url.Content("~/Scripts/jquery-1.6.2.js")"></script> 1: <script type="text/javascript" src="@Url.Content("~/Scripts/jquery.unobtrusive-ajax.js")">
</script>
</head>
<body>
@using (Ajax.BeginForm("ProcessOrder", new AjaxOptions()))
{
for (int i = 0; i < Model.Count; i++)
{
<li>
@Html.HiddenFor(m=>m[i].Id)
@Html.HiddenFor(m => m[i].Name)
@Html.DisplayFor(m => m[i].Name):
@Html.EditorFor(m => m[i].Quantity)
</li>
}
<input type="submit" value="提交订单" />
}
</body>
</html>
4、运行结果:一个包含三个商品的购物车信息会被呈现出来,当我们输入相应的订购数量并点击“提交订单”后,订单处理结果消息会弹出来。下图所示的就是库存不足的情况下显示的消息。
- mvc中@helper的用法
- mvc中partialview
- MVC JsonResult的用法
- python如何编写一个用户登录系统(Python实现的登录验证系统完整案例基于搭建的MVC框架)
- MVC中outputcache缓存
- php框架使用方法大全(PHP MVC框架中类的自动加载机制实例分析)
- php框架初始化教程学习(PHP从零开始打造自己的MVC框架之类的自动加载实现方法详解)
- MVC过滤器的用法
- MVC Model验证
- MVC中使用jQuery加载分部视图(PartialView)
- MVC升级后报"当前上下文中不存在ViewBag"错的解决方法
- Asp.net Mvc模型绑定
- MVC扩展HtmlHelper实现CheckBoxList
- mysql mvcc 底层原理(浅析MySQL - MVCC)
- 使用RouteDebugger对MVC路由进行调试
- mvc编译时,让View中的错误提示
- 关于队徽 你了解这些么 二(关于队徽你了解这些么)
- 冬天来了手脚冰凉 真不是因为上辈子你是折翼的天使(冬天来了手脚冰凉)
- 0 1 岁婴儿最强作息指南,照着做养出天使宝宝(01岁婴儿最强作息指南)
- 沪上这16所高校 萌新 礼包开箱 哪一款让你心动(沪上这16所高校萌新)
- 她救了被绑架的他,而这一切竟是一场阴谋...(她救了被绑架的他)
- 冬季养殖这6种阴生植物,方便又好养,你家有么(冬季养殖这6种阴生植物)
热门推荐
- linux怎么设置php代码(linux Cron定时执行带参数的PHP代码)
- pandas画布设置数据标签(pandas dataframe添加表格框线输出的方法)
- zabbix监控页面(Zabbix WEB监测实现过程图解)
- mysql 8.0.22 winx64安装配置方法图文教程(mysql 8.0.22 winx64安装配置方法图文教程)
- python类中的数据封装(基于python生成器封装的协程类)
- python正则表达式该怎么学习(Python面向对象总结及类与正则表达式详解)
- SQL SERVER中Merge语句的用法
- amazeui怎么设置侧边栏(AmazeUI 等分网格的实现示例)
- C# 获取磁盘空间大小
- servlet与tomcat区别(深入了解tomcat中servlet的创建方式实现)