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

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

                columns: [
                    { field: "Name", expandable: true, title: "名称", width: 250 },
                    { field: "Code", title: "编号" },
                    { field: "Lv", title: "级别", width: "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;
        }

  

转载于:https://www.cnblogs.com/wjx-blog/p/9419499.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值