Kendo 网格内联编辑中的多选列表
Multiselect list in Kendo Grid inline editing
我需要在 kendo 网格(内联编辑)中使用 multiselect 列表,以便用户可以从每行列表中 select 多个值。
以下是我的要求:
- 在显示时,kendo 网格应显示所有 selected 值的逗号分隔列表。
- 添加时,kendo 网格应显示多个 select 列表并允许 select 多个值。
- 编辑时,kendo 网格应显示包含已 select 编辑值的多个 select 列表。用户应该能够修改列表中的 select 和 add/remove 项。
当用户点击 update/save 按钮时,来自 multiselect 列表的 selected 值应该在后面的代码中可用(在更新 ajax 操作中)以及 id行数。
以下是我目前所做的:
我采用的方法类似于在 kendo 内联网格中使用下拉列表。
我在 add/edit 时创建了一个用于显示 multiselect 的编辑器模板。
代码如下:
@model List<Namespace.CompanyConnector>
@using Kendo.Mvc.UI
@(Html.Kendo().MultiSelectFor(c=>c)
.Name("company_connector_id")
.DataTextField("connector_name")
.DataValueField("company_connector_id")
.Placeholder("Select connector...")
.AutoBind(false)
.Value((List<int>)ViewData["SelectedValues"])
.DataSource(source =>
{
source.Read(read =>
{
read.Action("GetCompanyConnectors", "BrandConnector");
})
.ServerFiltering(true);
})
)
@Html.ValidationMessageFor(m => m)
说明:我将模型class 的列表绑定到multiselect 并在读取操作中设置数据源。对于在编辑时 selecting selected 值,我创建了一个函数,该函数 returns selected 值的 ids 并将其放在 View Data 中阅读动作。
我在我的索引页面中使用了这个编辑器模板,代码如下:
@{Html.Kendo().Grid<Cee.DomainObjects.DomainObjects.BrandConnector>()
.Name("BrandConnectorGrid")
.Filterable()
.Events(e => e.Edit("onEdit"))
.DataSource(dataSource => dataSource
.Ajax()
.Events(e => e.Error("error_handler").RequestEnd("onRequestEnd"))
.ServerOperation(false)
.Model(model =>
{
model.Id(p => p.brand_id);
model.Field(e => e.CompanyConnectorList).DefaultValue(new
List<Cee.DomainObjects.DomainObjects.CompanyConnector>());
})
.Read(read => read.Action("_AjaxBinding", "BrandConnector",new{companyID = 0 }).Type(HttpVerbs.Post))
.Update(update => update.Action("_UpdateBinding", "BrandConnector").Type(HttpVerbs.Post)))
.Columns(columns =>
{
columns.Bound(c => c.brand_connector_id).Width(0).Hidden(true);
columns.Bound(c => c.company_id).Width(0).Hidden(true);
columns.Bound(c => c.brand_id).Width(0).Hidden(true);
columns.Bound(u => u.brand_name).Title("Brand").Width("18%").HtmlAttributes(new { @class = "brkWord", @readonly = "readonly" });
columns.ForeignKey(u => u.connector_name, Model.CompanyConnectorList, "company_connector_id", "connector_name").Title("Connector").Width
("16%").HtmlAttributes(new { @class = "brkWord" }).EditorTemplateName("company_connector_id");
columns.Command(p => p.Edit().Text("Edit").HtmlAttributes(new { @title = "Edit" })).Width("16%").Title("Edit");
})
.Editable(editable => editable.Mode(GridEditMode.InLine).CreateAt(GridInsertRowPosition.Top))
.Pageable(pageable => pageable.Refresh(true).PageSizes(GlobalCode.recordPerPageList).ButtonCount(GlobalCode.PageSize).Input(true).Numeric(true))
.HtmlAttributes(new { @class = "dynamicWidth" })
.Sortable(sorting => sorting.Enabled(true))
.Render();
}
说明:我用过外键。将它绑定到字符串列 "connector_name"。 Connector_name 是我从控制器发送的以逗号分隔的 ID 列表。这里使用编辑器模板。
问题:它在索引 View/Display 时工作正常,但编辑不显示 selected 值。我们也没有在更新点击后的代码中获得更新值。
这是实现 multiselect 列表的正确方法还是我需要将集合 属性 绑定为网格中的列?
如果我将一个集合 属性 绑定为一个列,那么我将如何在显示时显示逗号分隔的字符串?
试一试:
<code>c.Bound(p => p.CompanyConnectorList).ClientTemplate("#= connectorsToString(data)#").EditorTemplateName("company_connector_id");
和 js:
</p>
<pre><code>function connectorsToString(data) {
var list = data.company_connector_id;
var result = "";
for (var i = 0; i < list.length; i++) {
result += list[i].Name + ';';
}
return result;
}
试试下面的代码:
function onEdit(e) {
var multiselect = $("#YourMutliselectDropdown").data("kendoMultiSelect");
var IDArray = [];
$(e.model.propertyName).each(function (index) {
var ID = e.model.propertyName[index].id;
IDArray.push(ID);
});
multiselect.value(IDArray);
}
我假设 propertyName
是您的 collection 列表,它包含 id
作为 属性。
我需要在 kendo 网格(内联编辑)中使用 multiselect 列表,以便用户可以从每行列表中 select 多个值。
以下是我的要求:
- 在显示时,kendo 网格应显示所有 selected 值的逗号分隔列表。
- 添加时,kendo 网格应显示多个 select 列表并允许 select 多个值。
- 编辑时,kendo 网格应显示包含已 select 编辑值的多个 select 列表。用户应该能够修改列表中的 select 和 add/remove 项。
当用户点击 update/save 按钮时,来自 multiselect 列表的 selected 值应该在后面的代码中可用(在更新 ajax 操作中)以及 id行数。
以下是我目前所做的:
我采用的方法类似于在 kendo 内联网格中使用下拉列表。
我在 add/edit 时创建了一个用于显示 multiselect 的编辑器模板。
代码如下:
@model List<Namespace.CompanyConnector>
@using Kendo.Mvc.UI
@(Html.Kendo().MultiSelectFor(c=>c)
.Name("company_connector_id")
.DataTextField("connector_name")
.DataValueField("company_connector_id")
.Placeholder("Select connector...")
.AutoBind(false)
.Value((List<int>)ViewData["SelectedValues"])
.DataSource(source =>
{
source.Read(read =>
{
read.Action("GetCompanyConnectors", "BrandConnector");
})
.ServerFiltering(true);
})
)
@Html.ValidationMessageFor(m => m)
说明:我将模型class 的列表绑定到multiselect 并在读取操作中设置数据源。对于在编辑时 selecting selected 值,我创建了一个函数,该函数 returns selected 值的 ids 并将其放在 View Data 中阅读动作。
我在我的索引页面中使用了这个编辑器模板,代码如下:
@{Html.Kendo().Grid<Cee.DomainObjects.DomainObjects.BrandConnector>()
.Name("BrandConnectorGrid")
.Filterable()
.Events(e => e.Edit("onEdit"))
.DataSource(dataSource => dataSource
.Ajax()
.Events(e => e.Error("error_handler").RequestEnd("onRequestEnd"))
.ServerOperation(false)
.Model(model =>
{
model.Id(p => p.brand_id);
model.Field(e => e.CompanyConnectorList).DefaultValue(new
List<Cee.DomainObjects.DomainObjects.CompanyConnector>());
})
.Read(read => read.Action("_AjaxBinding", "BrandConnector",new{companyID = 0 }).Type(HttpVerbs.Post))
.Update(update => update.Action("_UpdateBinding", "BrandConnector").Type(HttpVerbs.Post)))
.Columns(columns =>
{
columns.Bound(c => c.brand_connector_id).Width(0).Hidden(true);
columns.Bound(c => c.company_id).Width(0).Hidden(true);
columns.Bound(c => c.brand_id).Width(0).Hidden(true);
columns.Bound(u => u.brand_name).Title("Brand").Width("18%").HtmlAttributes(new { @class = "brkWord", @readonly = "readonly" });
columns.ForeignKey(u => u.connector_name, Model.CompanyConnectorList, "company_connector_id", "connector_name").Title("Connector").Width
("16%").HtmlAttributes(new { @class = "brkWord" }).EditorTemplateName("company_connector_id");
columns.Command(p => p.Edit().Text("Edit").HtmlAttributes(new { @title = "Edit" })).Width("16%").Title("Edit");
})
.Editable(editable => editable.Mode(GridEditMode.InLine).CreateAt(GridInsertRowPosition.Top))
.Pageable(pageable => pageable.Refresh(true).PageSizes(GlobalCode.recordPerPageList).ButtonCount(GlobalCode.PageSize).Input(true).Numeric(true))
.HtmlAttributes(new { @class = "dynamicWidth" })
.Sortable(sorting => sorting.Enabled(true))
.Render();
}
说明:我用过外键。将它绑定到字符串列 "connector_name"。 Connector_name 是我从控制器发送的以逗号分隔的 ID 列表。这里使用编辑器模板。
问题:它在索引 View/Display 时工作正常,但编辑不显示 selected 值。我们也没有在更新点击后的代码中获得更新值。
这是实现 multiselect 列表的正确方法还是我需要将集合 属性 绑定为网格中的列? 如果我将一个集合 属性 绑定为一个列,那么我将如何在显示时显示逗号分隔的字符串?
试一试:
<code>c.Bound(p => p.CompanyConnectorList).ClientTemplate("#= connectorsToString(data)#").EditorTemplateName("company_connector_id");
和 js:
</p>
<pre><code>function connectorsToString(data) {
var list = data.company_connector_id;
var result = "";
for (var i = 0; i < list.length; i++) {
result += list[i].Name + ';';
}
return result;
}
试试下面的代码:
function onEdit(e) {
var multiselect = $("#YourMutliselectDropdown").data("kendoMultiSelect");
var IDArray = [];
$(e.model.propertyName).each(function (index) {
var ID = e.model.propertyName[index].id;
IDArray.push(ID);
});
multiselect.value(IDArray);
}
我假设 propertyName
是您的 collection 列表,它包含 id
作为 属性。