2011-06-07 164 views
0

我找不到任何示例如何使用MVC jQGrid做客戶端驗證。 對於客戶端,我可以看到,我需要分配列屬性EditClientSideValidatorsASP.NET MVC jQGrid客戶端和服務器端驗證

public List<JQGridEditClientSideValidator> EditClientSideValidators { get; set; }

,但我不能瞭解如何驗證分配給。

但如何做服務器驗證它也是一個問題

UPDATE

我想我發現了一些客戶端驗證http://www.trirand.net/aspnetmvc/grid/editclientsidevalidation

回答

0

如果你抓住了,其中包括支持,你可以問許可證開發者...否則,你顯示的鏈接有文檔...網格需要在獲取數據時請求驗證器,如下所示:

public void SetUpGrid_EditClientSideValidation(JQGrid grid) 
{ 
    // Setting the DataUrl to an action (method) in the controller is required. 
    // This action will return the data needed by the grid. 
    // EditUrl will point to the editing action 
    grid.DataUrl = Url.Action("EditClientSideValidation_DataRequested"); 
    grid.EditUrl = Url.Action("EditClientSideValidation_EditRow"); 

    var integerColumn = grid.Columns.Find(c => c.DataField == "Integer"); 
    integerColumn.EditClientSideValidators.Add(new RequiredValidator()); 
    integerColumn.EditClientSideValidators.Add(new MinValueValidator { MinValue = 10 }); 
    integerColumn.EditClientSideValidators.Add(new MaxValueValidator { MaxValue = 100 }); 

    var numberColumn = grid.Columns.Find(c => c.DataField == "Number"); 
    numberColumn.EditClientSideValidators.Add(new RequiredValidator()); 
    numberColumn.EditClientSideValidators.Add(new MinValueValidator { MinValue = 0.1 }); 
    numberColumn.EditClientSideValidators.Add(new MaxValueValidator { MaxValue = 100.1 }); 

    var emailColumn = grid.Columns.Find(c => c.DataField == "Email"); 
    emailColumn.EditClientSideValidators.Add(new RequiredValidator()); 
    emailColumn.EditClientSideValidators.Add(new EmailValidator()); 

    var linkColumn = grid.Columns.Find(c => c.DataField == "Link"); 
    linkColumn.EditClientSideValidators.Add(new RequiredValidator()); 
    linkColumn.EditClientSideValidators.Add(new UrlValidator()); 

    var customColumn = grid.Columns.Find(c => c.DataField == "Custom"); 
    customColumn.EditClientSideValidators.Add(new Trirand.Web.Mvc.CustomValidator { ValidationFunction = "validateCustomField" }); 
    } 

// This method is called when the grid requests data. You can choose any method to call 
// by setting the JQGrid.DataUrl property 
public JsonResult EditClientSideValidation_DataRequested() 
{ 
    // Get both the grid Model 
    // The data model in our case is an autogenerated linq2sql database based on Northwind. 
    var gridModel = new EditValidationModel(); 
    SetUpGrid_EditClientSideValidation(gridModel.ValidatedGrid); 

    // return the result of the DataBind method, passing the datasource as a parameter 
    // jqGrid for ASP.NET MVC automatically takes care of paging, sorting, filtering/searching, etc 
    List employees = GetClientValidatedEmployeeData(); 
    return gridModel.ValidatedGrid.DataBind(employees.AsQueryable()); 
}