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++)
{
<div>
@Html.HiddenFor(m=>m[i].Id)
@Html.HiddenFor(m => m[i].Name)
@Html.DisplayFor(m => m[i].Name):
@Html.EditorFor(m => m[i].Quantity)
</div>
}
<input type="submit" value="提交订单" />
}
</body>
</html>

4、运行结果:一个包含三个商品的购物车信息会被呈现出来,当我们输入相应的订购数量并点击“提交订单”后,订单处理结果消息会弹出来。下图所示的就是库存不足的情况下显示的消息。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具