1

フォームがあり、Grid.MVC を使用して同じページに表示します。プログラムを実行しようとすると、エラーが表示されます:「モデル」は宣言「System.Web.Mvc.WebViewPage.Model」と競合しています..

ここに私のコードのサンプル

これは私のモデルです

public class Course
{
    [DisplayName("Customer Name")]
    public string customer { get; set; }

    [DisplayName("Contact")]
    public string contact { get; set; }

    [UIHint("DropDownList")]
    [Required(ErrorMessage = "Please select the package")]
    public int CoursePackageID { get; set; }

    [Required]
    public int CustomerID { get; set; }

    [Required(ErrorMessage = "The date is required")]
    [DisplayName("Date Of Register")]
    public DateTime dtRegister { get; set; }

    [DisplayName("Payment")]
    public string payment { get; set; }

    public List<CourseObject> lCourse { get; set; }

    public class CourseObject
    {       
        public int courseId { get; set; }

        [DisplayName("Package")]
        public string package { get; set; }
        [DisplayName("Date Of Register")]
        public DateTime date_register { get; set; }
        [DisplayName("Payment")]
        public string payment { get; set; }
    } 

}

そして、これは私の CSHTML (Razor) です

@model BangiProject.Models.Course
@using GridMvc.Html
@{
    ViewBag.Title = "Register";
}
<h2>
    Register</h2>
@using (Html.BeginForm())
{
    @Html.ValidationSummary(true)

    <fieldset>
        <legend>Course</legend>
        <div class="control-label">
            @Html.LabelFor(model => model.customer)
        </div>
        <div class="form-control-static">
            @Html.DisplayFor(model => model.customer)
        </div>
        <div class="control-label">
            @Html.LabelFor(model => model.contact)
        </div>
        <div class="form-control-static">
            @Html.DisplayFor(model => model.contact)
        </div>
        <div class="editor-label">
            Category :
        </div>
        <div class="editor-field">
            @Html.DropDownListFor(Model => Model.CoursePackageID, new SelectList(ViewBag.CoursePackage as System.Collections.IEnumerable, "id", "course_name", new { @style = "drop-down" }),
            "-Choose Package-", new { id = "cat" })
        </div>
        <div class="editor-label">
            @Html.LabelFor(model => model.dtRegister)
        </div>
        <div class="editor-field">
            @Html.EditorFor(model => model.dtRegister)
            @Html.ValidationMessageFor(model => model.dtRegister)
        </div>
        <div class="editor-label">
            @Html.LabelFor(model => model.payment)
        </div>
        <div class="editor-field">
            @Html.EditorFor(model => model.payment)
            @Html.ValidationMessageFor(model => model.payment)
        </div>
        <p>
            <input type="submit" value="Create" />
        </p>
    </fieldset>
}
<div class="row">
    @Html.Grid(Model.lCourse).Columns(columns =>
                    {
                        columns.Add(c => c.courseId).Titled("ID")
                            .Sanitized(false)
                            .Encoded(false)
                            .RenderValueAs(o => Html.ActionLink("Edit", "Edit", "Merchant", new { id = o.courseId }, null).ToHtmlString());

                        columns.Add(c => c.package).Titled("Package").Filterable(true);

                        columns.Add(c => c.date_register).Titled("Date Of Register").Filterable(true);


                    }).WithPaging(25).Sortable(true)
</div>
<div>
    @Html.ActionLink("Back to List", "Index")
</div>
@section Scripts {
    @Scripts.Render("~/bundles/jqueryval")
}

この行に表示されるエラー

@Html.Grid(Model.lCourse).Columns

ご意見をお聞かせください...

4

2 に答える 2

1

通常、これは、予約済みの「モデル」キーワードをどこかで誤って使用していることを意味します。あなたの場合:

@Html.DropDownListFor(Model => Model.CoursePackageID...

これを次のように変更します。

@Html.DropDownListFor(model => model.CoursePackageID...
于 2015-03-12T07:31:05.843 に答える
0

問題の行を以下のように変更してみてください (小文字の 'm')...

@Html.Grid(model.lCourse).Columns
于 2015-03-12T07:34:29.840 に答える