• kendo ui treelist popup 模式下 实现下拉框控件形式展示


    1、在列后面增加editor和template属性,其中levelDropDownEditor是一个方法,LvDisplayName是下拉框的Text值的字段名(用于在列表里显示)

                    columns: [
                        { field: "Name", expandable: true, title: "名称",  250 },
                        { field: "Code", title: "编号" },
                        { field: "Lv", title: "级别",  "180px", editor: levelDropDownEditor, template: "#=LvDisplayName#" }
                    ]
    

    2、实现levelDropDownEditor方法,其中的DropdownlistValue,是我加上的特殊标识,用于后台的数据读取,因为后台自定了一个字段名叫:"LvDropdownlistValue"。

        function levelDropDownEditor(container, options) {
            var jqueryElement = $('<input required name="' + options.field + 'DropdownlistValue" />');
            jqueryElement
                .appendTo(container)
                .kendoDropDownList({
                    autoBind: true,
                    dataTextField: "DisplayCode",
                    dataValueField: "ParaCode",
                    dataSource: {
                        transport: {
                            read: {
                                dataType: "jsonp",
                                url: "@Url.Content("~/BaseInfoManagement/Department/GetDepartmentLevelList")",
                            }
                        }
                    },
                    value: options.model.Lv,
                    dataBound: onDataBound
                });
        }

    3、后台update方法的实现

    public JsonResult Update()
            {
                dvaContext context = new dvaContext();
                JsonResult json = new JsonResult();
                var tempObj = new Cust_department_info();
                if (ModelState.IsValid)
                {
                    string jsonData = this.Request["models"];
                    List<Cust_department_info> lst = JsonConvert.DeserializeObject<List<Cust_department_info>>(jsonData);
                    foreach (var obj in lst)
                    {
                        var objNew = context.department_info.Find(obj.ID);
                        List<department_info> children = context.department_info.Where(m => m.ParentCode == objNew.Code).ToList();
                        objNew.Name = obj.Name;
                        objNew.Code = obj.Code;
                        objNew.Lv = obj.LvDropdownlistValue.ParaCode;
                        foreach (var b in children)
                        {
                            b.ParentCode = objNew.Code;
                        }
                    }
                    context.SaveChanges();
                }
                json.Data = new { success = true, msg = "更新成功!" };
                return json;
            }
    

      

  • 相关阅读:
    在老王指导下第一次完成购物车!!!
    自己封装的getElementByClassName函数,解决部分浏览器不兼容的问题
    第一次用js实现window10日历----动态的哟!
    第一次完成注册页面!分享一下,哈哈哈!
    array和string的方法
    js关于函数全局变量和局部变量的区分
    CSS3的3D效果样式transform属性中的rotate3d
    css中的 权重
    margin padding 和边框线的使用
    图片bug
  • 原文地址:https://www.cnblogs.com/wjx-blog/p/9419499.html
Copyright © 2020-2023  润新知