Вот моя попытка ускорить процесс для вас:
http://jsfiddle.net/5t5c2g1y/2/
var ds1 = new kendo.data.DataSource({
data: createRandomData(500),
scrollable: true,
schema: {
model: {
id: "id",
fields: {
id: {
type: 'number',
editable: true
},
FirstName: {
type: 'string',
editable: true
},
LastName: {
type: 'string',
editable: true
}
}
}
}
});
var ds2 = new kendo.data.DataSource({
data: createRandomData(0),
scrollable: true,
schema: {
model: {
id: "id",
fields: {
id: {
type: 'number',
editable: true
},
FirstName: {
type: 'string',
editable: true
},
LastName: {
type: 'string',
editable: true
}
}
}
}
});
var sourcegrid = $("#usersGrid").kendoGrid({
dataSource: ds1,
editable: "popup",
selectable: "multiple",
pageable: false,
columns: [{
field: "FirstName",
width: 90,
title: "First Name"
}, {
field: "LastName",
width: 90,
title: "Last Name"
}]
}).data("kendoGrid");
var destinationgrid = $("#teamGrid").kendoGrid({
dataSource: ds2,
editable: "popup",
selectable: "multiple",
pageable: false,
columns: [{
field: "FirstName",
width: 90,
title: "First Name"
}, {
field: "LastName",
width: 90,
title: "Last Name"
}]
}).data("kendoGrid");
$('input[type=button]').on('click',function() {
var removalList = [];
sourcegrid.select().each(function() {
var dataItem = sourcegrid.dataItem($(this));
console.log(dataItem);
removalList.push(dataItem)
ds2.add(dataItem);
});
for(var i = 0; i< removalList.length;i++)
{
ds1.remove(removalList[i]);
}
});
Если вы взаимодействуете с источниками данных, а не сами сетки, вы, надеюсь, увидите процесс намного быстрее (плюс g ets избавиться от всплывающего сообщения с просьбой подтвердить удаление)
Вы заметите, что я добавил консольный оператор, чтобы вы могли видеть, как копируется информация.
Снова надеемся, что это поможет.
Возможно, это лучше подходит для http://codereview.stackexchange.com –