ฉันกำลังพยายามสร้างการกระทำของตัวควบคุมซึ่งจะส่งคืน JSON หรือ HTML บางส่วนขึ้นอยู่กับพารามิเตอร์ วิธีที่ดีที่สุดในการรับผลลัพธ์ที่ส่งคืนไปยังหน้า MVC แบบอะซิงโครนัสคืออะไร
ฉันกำลังพยายามสร้างการกระทำของตัวควบคุมซึ่งจะส่งคืน JSON หรือ HTML บางส่วนขึ้นอยู่กับพารามิเตอร์ วิธีที่ดีที่สุดในการรับผลลัพธ์ที่ส่งคืนไปยังหน้า MVC แบบอะซิงโครนัสคืออะไร
คำตอบ:
ในวิธีการกระทำของคุณให้ส่งคืน Json (วัตถุ) เพื่อกลับ JSON ไปยังหน้า
public ActionResult SomeActionMethod() {
return Json(new {foo="bar", baz="Blech"});
}
จากนั้นเพียงเรียกวิธีการดำเนินการโดยใช้ Ajax คุณสามารถใช้หนึ่งในวิธีการช่วยเหลือจาก ViewPage เช่น
<%= Ajax.ActionLink("SomeActionMethod", new AjaxOptions {OnSuccess="somemethod"}) %>
SomeMethod จะเป็นวิธี javascript ที่ประเมินค่าวัตถุ Json ที่ส่งคืน
หากคุณต้องการส่งคืนสตริงธรรมดาคุณสามารถใช้ ContentResult:
public ActionResult SomeActionMethod() {
return Content("hello world!");
}
ContentResult โดยดีฟอลต์ส่งคืนข้อความ / ธรรมดาเป็น contentType
นี่เป็นภาระที่มากเกินไปดังนั้นคุณสามารถทำสิ่งต่อไปนี้
return Content("<xml>This is poorly formatted xml.</xml>", "text/xml");
ฉันคิดว่าคุณควรพิจารณา AcceptTypes ของคำขอ ฉันใช้มันในโครงการปัจจุบันของฉันเพื่อคืนประเภทเนื้อหาที่ถูกต้องดังนี้
การกระทำของคุณในคอนโทรลเลอร์สามารถทดสอบได้บนวัตถุคำขอ
if (Request.AcceptTypes.Contains("text/html")) {
return View();
}
else if (Request.AcceptTypes.Contains("application/json"))
{
return Json( new { id=1, value="new" } );
}
else if (Request.AcceptTypes.Contains("application/xml") ||
Request.AcceptTypes.Contains("text/xml"))
{
//
}
จากนั้นคุณสามารถใช้ aspx ของมุมมองเพื่อรองรับกรณีตอบสนอง xhtml บางส่วน
จากนั้นใน jQuery คุณสามารถดึงมันผ่านพารามิเตอร์ประเภทเป็น json:
$.get(url, null, function(data, textStatus) {
console.log('got %o with status %s', data, textStatus);
}, "json"); // or xml, html, script, json, jsonp or text
หวังว่านี่จะช่วยเจมส์
อีกวิธีที่ดีในการจัดการกับข้อมูล JSON คือการใช้ฟังก์ชัน JQuery getJSON คุณสามารถโทรหา
public ActionResult SomeActionMethod(int id)
{
return Json(new {foo="bar", baz="Blech"});
}
วิธีการจากวิธี jquery getJSON เพียงแค่ ...
$.getJSON("../SomeActionMethod", { id: someId },
function(data) {
alert(data.foo);
alert(data.baz);
}
);
return Json(new {foo="bar", baz="Blech"});
ทำ!
ฉันพบปัญหาสองสามข้อในการใช้ MVC ajax GET กับ JQuery ทำให้ฉันปวดหัวดังนั้นการแบ่งปันโซลูชันที่นี่
JsonRequestBehavior.AllowGet
; หากไม่มี MVC นี้จะส่งคืนข้อผิดพลาด HTTP 500 (ด้วยdataType: json
ตามที่ระบุไว้ในไคลเอนต์)cache: false
ไปยังการโทร $ .ajax มิฉะนั้นคุณจะได้รับการตอบกลับ HTTP 304 (แทนการตอบกลับ HTTP 200) ในที่สุดและเซิร์ฟเวอร์จะไม่ประมวลผลคำขอของคุณตัวอย่าง JQuery:
$.ajax({
type: 'get',
dataType: 'json',
cache: false,
url: '/MyController/MyMethod',
data: { keyid: 1, newval: 10 },
success: function (response, textStatus, jqXHR) {
alert(parseInt(response.oldval) + ' changed to ' + newval);
},
error: function(jqXHR, textStatus, errorThrown) {
alert('Error - ' + errorThrown);
}
});
ตัวอย่างรหัส MVC:
[HttpGet]
public ActionResult MyMethod(int keyid, int newval)
{
var oldval = 0;
using (var db = new MyContext())
{
var dbRecord = db.MyTable.Where(t => t.keyid == keyid).FirstOrDefault();
if (dbRecord != null)
{
oldval = dbRecord.TheValue;
dbRecord.TheValue = newval;
db.SaveChanges();
}
}
return Json(new { success = true, oldval = oldval},
JsonRequestBehavior.AllowGet);
}
หากต้องการตอบคำถามอีกครึ่งหนึ่งคุณสามารถโทร:
return PartialView("viewname");
เมื่อคุณต้องการส่งคืน HTML บางส่วน คุณจะต้องหาวิธีที่จะตัดสินใจว่าคำขอนั้นต้องการ JSON หรือ HTML ซึ่งอาจขึ้นอยู่กับส่วน / พารามิเตอร์ของ URL
โซลูชันทางเลือกที่มีกรอบการเข้ารหัส
แอ็คชันส่งคืน json
ตัวควบคุม
[HttpGet]
public ActionResult SomeActionMethod()
{
return IncJson(new SomeVm(){Id = 1,Name ="Inc"});
}
หน้ามีดโกน
@using (var template = Html.Incoding().ScriptTemplate<SomeVm>("tmplId"))
{
using (var each = template.ForEach())
{
<span> Id: @each.For(r=>r.Id) Name: @each.For(r=>r.Name)</span>
}
}
@(Html.When(JqueryBind.InitIncoding)
.Do()
.AjaxGet(Url.Action("SomeActionMethod","SomeContoller"))
.OnSuccess(dsl => dsl.Self().Core()
.Insert
.WithTemplate(Selector.Jquery.Id("tmplId"))
.Html())
.AsHtmlAttributes()
.ToDiv())
Action ส่งคืน html
ตัวควบคุม
[HttpGet]
public ActionResult SomeActionMethod()
{
return IncView();
}
หน้ามีดโกน
@(Html.When(JqueryBind.InitIncoding)
.Do()
.AjaxGet(Url.Action("SomeActionMethod","SomeContoller"))
.OnSuccess(dsl => dsl.Self().Core().Insert.Html())
.AsHtmlAttributes()
.ToDiv())
คุณอาจต้องการดูบทความที่มีประโยชน์มากซึ่งครอบคลุมเรื่องนี้อย่างมาก!
แค่คิดว่ามันอาจช่วยให้ผู้คนค้นหาวิธีแก้ไขปัญหาที่ดี
http://weblogs.asp.net/rashid/archive/2009/04/15/adaptive-rendering-in-asp-net-mvc.aspx
PartialViewResult และ JSONReuslt สืบทอดมาจากคลาสฐาน ActionResult ดังนั้นหากประเภทการส่งคืนได้รับการตัดสินใจประกาศวิธีการส่งออกแบบไดนามิกเป็น ActionResult
public ActionResult DynamicReturnType(string parameter)
{
if (parameter == "JSON")
return Json("<JSON>", JsonRequestBehavior.AllowGet);
else if (parameter == "PartialView")
return PartialView("<ViewName>");
else
return null;
}
สำหรับผู้ที่อัพเกรดเป็น MVC 3 นี่เป็นวิธีที่เรียบร้อยใน การใช้ MVC3 และ Json
public ActionResult GetExcelColumn()
{
List<string> lstAppendColumn = new List<string>();
lstAppendColumn.Add("First");
lstAppendColumn.Add("Second");
lstAppendColumn.Add("Third");
return Json(new { lstAppendColumn = lstAppendColumn, Status = "Success" }, JsonRequestBehavior.AllowGet);
}
}
วิธีการที่ยืดหยุ่นในการผลิตผลที่แตกต่างตามคำขอ
public class AuctionsController : Controller
{
public ActionResult Auction(long id)
{
var db = new DataContext();
var auction = db.Auctions.Find(id);
// Respond to AJAX requests
if (Request.IsAjaxRequest())
return PartialView("Auction", auction);
// Respond to JSON requests
if (Request.IsJsonRequest())
return Json(auction);
// Default to a "normal" view with layout
return View("Auction", auction);
}
}
Request.IsAjaxRequest()
วิธีค่อนข้างง่าย: มันเป็นเพียงการตรวจสอบส่วนหัว HTTP สำหรับการร้องขอเข้ามาเพื่อดูว่าค่าของ X-ขอ-ด้วยส่วนหัวXMLHttpRequest
ซึ่งถูกผนวกโดยอัตโนมัติจากเบราว์เซอร์ส่วนใหญ่และกรอบ AJAX
วิธีการขยายที่กำหนดเองเพื่อตรวจสอบว่าการร้องขอสำหรับ json หรือไม่เพื่อให้เราสามารถโทรได้จากทุกที่เช่นเดียวกับวิธีการร้องขอ Request.IsAjaxRequest ():
using System;
using System.Web;
public static class JsonRequestExtensions
{
public static bool IsJsonRequest(this HttpRequestBase request)
{
return string.Equals(request["format"], "json");
}
}