无法编辑kendo网格

时间:2013-12-17 06:45:07

标签: jquery asp.net-mvc kendo-grid

我无法编辑内联网格和弹出窗口。单击“保存”按钮时,我的动作方法无法获取当前编辑单元格的值。

             <div class="home-index">
            <div class="location-grid" data-bind="source: dataSource"></div>

            <script id="rowTemplate" type="text/x-kendo-tmpl">
                        <tr>
                            <td class="boldColumn">
                               #: data.FirstName #
                            </td>
                            <td onclick='showValue("#: data.LastName #")'>
                                #: data.LastName #
                            </td>
                            <td>
                               #: data.Latitude #
                            </td>
                            <td>
                               #: data.Longitude #
                            </td>
                            <td>
                               #: data.IsActive #
                            </td>
                       </tr>
            </script>


            <script>
                var LocationInfo = function () {
                    var vm;
                    var init = function () {
                        vm = new kendo.data.ObservableObject({
                            dataSource: new kendo.data.DataSource({
                                transport: {
                                    read: "/Home/GetLocationInfos",
                                    update: {
                                        url: "/Home/Update",
                                        dataType: "json",
                                        type: "POST",
                                    },
                                    parameterMap: function (options, operation) {
                                        if (operation !== "read" && options.models) {
                                            return { models: kendo.stringify(vm.get("Selected")) };
                                        }
                                    }
                                },
                                schema: {
                                    model: {
                                        fields: {
                                            id: "ID",
                                            fields: {
                                                ID: { editable: false },
                                                FirstName: { validation: { required: true } },
                                                LastName: { validation: { required: true } },
                                                Latitude: { type: "number", validation: { required: true, min: 1 } },
                                                Longitude: { type: "number", validation: { required: true, min: 1 } },
                                                IsActive: { type: "boolean" }
                                            }
                                        }
                                    }
                                }
                            })
                        });

                        $(function () {
                            $(".location-grid").kendoGrid({
                                sortable: true,
                                selectable: true,
                                editable: "inline",
                                batch: true,
                                //rowTemplate: kendo.template($("#rowTemplate").html()),
                                //toolbar: ["create"],
                                columns: [
                                    {
                                        title: "First Name",
                                        field: "FirstName"
                                    },
                                    {
                                        title: "Last Name",
                                        field: "LastName"
                                    },
                                    {
                                        title: "Latitude",
                                        field: "Latitude",
                                    },
                                    {
                                        title: "Longitude",
                                        field: "Longitude",
                                    },
                                    {
                                        title: "IsActive",
                                        field: "IsActive",
                                    },
                                    {
                                        command: ["edit"],
                                    }

                                ]
                            });
                            kendo.bind($(".home-index"), vm);
                        });
                    };
                    init();
                    return {
                        viewModel: vm
                    };
                }();
            </script>
        </div>

        <style>
            .boldColumn {
                font-weight: bold;
            }
        </style>

控制器代码:

     public ActionResult GetLocationInfos()
    {
        using (var db = new PersonEntities())
        {
            var info = db.LocationInfoes.Take(10).ToList();
            return Json(info, JsonRequestBehavior.AllowGet);
        }

    }

    public ActionResult GetLocationInfo(long ID)
    {
        using (var db = new PersonEntities())
        {
            var info = db.LocationInfoes.FirstOrDefault(z => z.ID == ID);
            return Json(info, JsonRequestBehavior.AllowGet);
        }

    }

    public JsonResult Update(LocationInfo models)
    {
        using (var db = new PersonEntities())
        {
            db.LocationInfoes.AddOrUpdate(models);
            //db.SaveChanges();
        }
        return Json(new
        {
            success = true,
            data = models
        });
    }

在控制器中,我只获得空值。请帮助我,我想使用kendo mvvm teachnology。

1 个答案:

答案 0 :(得分:0)

它的愚蠢错误,如果我使用行模板,那么我也应该创建编辑模板。

我创建了编辑模板并解决了问题。