一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

Coolite Cool Study 3 MVC + Coolite 的實現代碼

MVC-Coolite

因為默認的 MVC 的樣式文件里對于的 table 和 其他相關樣式(h1~h6) 與Coolite有沖突,會導致GridPanel走樣,大家記得先把那個table 和  h1~h6的樣式清除掉才看到GridPanel的帥臉面 …

項目文件分布:

ProjectFiles

關于Coolite在MVC中的配置文件跟一般webform是一樣的。 但在MVC的Global.asax中,需要在 RegisterRoutes 方法里加上這一句:

routes.IgnoreRoute("{exclude}/{coolite}/coolite.axd");

另外 ScriptManager 要注明 IDMode="Static“:

<ext:ScriptManager ID="ScriptManager1" runat="server"  IDMode="Static"/>

其中唯一與一般MVC不同的是,我們需要定義自己的ActionResult來返回Json結果給客戶端。因為Coolite 的JsonReader 要求的格式大致都是這樣:{data: [{…}], totalCount: …}

關于JsonReader的一般用法:

<ext:JsonReader ReaderID="CustomerID" Root="data" TotalProperty="totalCount"> 

所以, 要繼承MVC ActionResult 的抽象方法 public override void ExecuteResult(ControllerContext context)  來返回給 JsonReader   合適口味的 JsonResult , 不然它就不認人了。

以下代碼實現了對Json Response & Save Response 的簡單封裝。

using System;using System.Collections.Generic;using System.Linq;using System.Web;using System.Web.Mvc;using Coolite.Ext.Web;namespace CooliteMVC.Helper{   public class AjaxStoreResult : ActionResult  {    public AjaxStoreResult() { }    public AjaxStoreResult(object data)    {      this.Data = data;    }    public AjaxStoreResult(object data, int totalCount)      : this(data)    {      this.TotalCount = totalCount;    }    public AjaxStoreResult(StoreResponseFormat responseFormat)    {      this.ResponseFormat = responseFormat;    }    private object data;    public object Data    {      get { return this.data; }      set { this.data = value; }    }    private int totalCount;    public int TotalCount    {      get { return this.totalCount; }      set { this.totalCount = value; }    }    private StoreResponseFormat responseFormat = StoreResponseFormat.Load;    public StoreResponseFormat ResponseFormat    {      get { return this.responseFormat; }      set { this.responseFormat = value; }    }    private SaveStoreResponse saveResponse;    public SaveStoreResponse SaveResponse    {      get      {        if (this.saveResponse == null)        {          this.saveResponse = new SaveStoreResponse();        }        return this.saveResponse;      }    }    public override void ExecuteResult(ControllerContext context)    {      switch (this.ResponseFormat)      {        case StoreResponseFormat.Load:          string json = Coolite.Ext.Web.JSON.Serialize(Data);          json = "{data:" + json + ", totalCount:" + 100 + "}";          context.HttpContext.Response.Write(json);                     break;        case StoreResponseFormat.Save:          Response response = new Response(true);          response.Success = this.SaveResponse.Success;          response.Msg = this.SaveResponse.ErrorMessage;          StoreResponseData saveResponse = new StoreResponseData();          saveResponse.Confirmation = this.SaveResponse.ConfirmationList;          response.Data = saveResponse.ToString();          response.Write();          break;        default:          throw new ArgumentOutOfRangeException();      }    }   }  public enum StoreResponseFormat  {    Load,    Save  }  public class SaveStoreResponse  {    private bool success = true;    private string errorMessage;    public bool Success    {      get { return this.success; }      set { this.success = value; }    }    public string ErrorMessage    {      get { return this.errorMessage; }      set { this.errorMessage = value; }    }    public ConfirmationList ConfirmationList { get; set; }  }}

AjaxStoreResult 在 CustomerController 中的使用:

using System;using System.Collections.Generic;using System.Linq;using System.Web;using System.Web.Mvc;using System.Web.Mvc.Ajax;using CooliteMVC.Models;using CooliteMVC.Helper;using Coolite.Ext.Web;namespace CooliteMVC.Controllers{  public class CustomerController : Controller  {    //    // GET: /Customer/    public ActionResult Index()    {      ViewData["Title"] = "Customer List";      ViewData["Message"] = "Welcome to Coolite MVC! My name is Bruce.";      return View();    }    public ActionResult List(int limit, int start, string dir, string sort)    {      Random rand = new Random();      IList<Customer> list = new List<Customer>();      for (int i = start; i < start + limit; i++)        list.Add(new Customer        {          CustomerID = "Customer" + i,          Address = "Address" + i,          City = "City" + rand.Next(1000),          CompanyName = "Com" + rand.Next(1000),          ContactName = "Contract" + rand.Next(1000),          ContactTitle = "Title" + rand.Next(1000),          Country = "Country" + rand.Next(1000),          Email = rand.Next(1000) + "@live.com",          Fax = rand.Next(1000).ToString() + rand.Next(1000),          Mobile = rand.Next(1000).ToString() + rand.Next(1000),          Notes = "Notes" + rand.Next(1000),          Phone = "Phone" + rand.Next(1000),          Region = "Region" + rand.Next(1000),          TranDate = DateTime.Now.AddDays(rand.Next(30))        });      return new AjaxStoreResult(list, 100);    }    public ActionResult Save()    {      AjaxStoreResult ajaxStoreResult = new AjaxStoreResult(StoreResponseFormat.Save);      try      {        StoreDataHandler dataHandler = new StoreDataHandler(Request["data"]);        ChangeRecords<Customer> data = dataHandler.ObjectData<Customer>();        foreach (Customer customer in data.Deleted)        {          //db.Customers.Attach(customer);          //db.Customers.DeleteOnSubmit(customer);        }        foreach (Customer customer in data.Updated)        {          //db.Customers.Attach(customer);          //db.Refresh(RefreshMode.KeepCurrentValues, customer);        }        foreach (Customer customer in data.Created)        {          //db.Customers.InsertOnSubmit(customer);        }      }      catch (Exception e)      {        ajaxStoreResult.SaveResponse.Success = false;        ajaxStoreResult.SaveResponse.ErrorMessage = e.Message;      }      return ajaxStoreResult;    }   }}

頁面的關鍵代碼:

   <ext:Store ID="dsCustomers" runat="server" >    <Proxy>      <ext:HttpProxy Url="/Customer/List" Method ="GET" />    </Proxy>    <UpdateProxy>       <ext:HttpWriteProxy Url="/Customer/Save" />    </UpdateProxy>    <Reader>      <ext:JsonReader ReaderID="CustomerID" Root="data" TotalProperty="totalCount">        <Fields>          <ext:RecordField Name="CustomerID" SortDir="ASC" />          <ext:RecordField Name="CompanyName" />          <ext:RecordField Name="ContactName" />          <ext:RecordField Name="Email" />          <ext:RecordField Name="Phone" />          <ext:RecordField Name="Fax" />          <ext:RecordField Name="Region" />          <ext:RecordField Name="TranDate" Type="Date" />        </Fields>      </ext:JsonReader>    </Reader>    <BaseParams>      <ext:Parameter Name="limit" Value="15" Mode="Raw" />      <ext:Parameter Name="start" Value="0" Mode="Raw" />      <ext:Parameter Name="dir" Value="ASC" />      <ext:Parameter Name="sort" Value="CustomerID" />    </BaseParams>    <SortInfo Field="CustomerID" Direction="ASC" />  </ext:Store>
我們可以看到其實就是Url的寫法不同而已:
 <ext:HttpProxy Url="/Customer/List" Method ="GET" />
 <ext:HttpWriteProxy Url="/Customer/Save" /> 
詳細頁面代碼跟第一章差不多,這里不列出來。 

AspNet技術Coolite Cool Study 3 MVC + Coolite 的實現代碼,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 91短视频在线观看2019 | 怡红院美国分院一区二区 | 亚洲国产欧美国产第一区二区三区 | 欧美日韩一区二区三 | 国产99r视频精品免费观看 | 2021国内精品久久久久久影院 | 在线天堂视频 | 色精品视频 | 淫啪| 两性午夜视频 | 久草新在线 | 六月婷婷综合激情 | 国产在线拍揄自揄视精品不卡 | 色宅男中文字幕亚洲专区 | 国产成人综合久久精品亚洲 | 2021国内精品久久久久久影院 | 亚洲人成伊人成综合网久久久 | 亚洲国产综合精品中文字幕 | 在线观看亚洲 | 欧美特黄高清免费观看的 | 日本一区二区视频免费播放 | 99视频有精品视频免费观看 | 日韩久久一区二区三区 | 国产精品手机在线亚洲 | 91性视频 | 亚洲大片免费观看 | 日韩精品第二页 | 国产情侣真实露脸在线 | 亚州一级毛片 | 日韩欧美一区黑人vs日本人 | 亚洲日本一区二区三区高清在线 | 色成人综合 | 亚洲一区二区三区久久精品 | 天天操天天透 | 五月天婷婷影院 | 日本网络视频www色高清免费 | 国内精品一区二区2021在线 | 91po国产在线高清福利 | 国产人成亚洲第一网站在线播放 | 国产成人久久精品激情 | 国产乱码一区二区三区四川人 |