Kendo UI で奇妙な問題が発生しました。これは理解できません。
これは私のコードです。
$(document).ready(function() {
var kendo_dataSource = new kendo.data.DataSource({
autoSync: true,
batch: true,
transport: {
read: {
url: "<?php echo BASE_URL . 'kendo/kendo_grid_read' ?>",
dataType: "json"
},
destroy: {
url: "<?php echo BASE_URL . 'kendo/kendo_grid_destroy' ?>",
dataType: "json",
type: "POST"
},
parameterMap: function(data, type) {
if (type == "destroy") {
return {models: data.models}
}
}
},
serverFiltering: true,
serverGrouping: true,
serverPaging: true,
page: 1,
pageSize: 5,
schema: {
data: "results",
total: "total",
model: {
id: "field1"
}
}
});
$("#kendo_grid2").kendoGrid({
dataSource: kendo_dataSource,
height: 300,
filterable: true,
sortable: true,
pageable: true,
selectable: "multiple row",
columns: [
{
field: "field1"
},
{
field: "field2"
},
{
field: "field3"
}
]
});
$("#test_button").on("click", function() {
var selectedRows = $("#kendo_grid2").data("kendoGrid").select();
if (selectedRows.length > 0) {
for (var i = 0; i < selectedRows.length; i++) {
var dataItem = $("#kendo_grid2").data("kendoGrid").dataItem(selectedRows[i]);
console.log(dataItem);
kendo_dataSource.remove(dataItem);
}
}
});
});
これが状況です。
が$("#test_button").on("click", function()
起動されると、グリッドで選択された行がチェックされ、行が削除されます。
2 行を選択すると、2 行が削除されます。そして、2 行がグリッドから消えます。
しかし、私は何か奇妙なものを見ます -
2 行が削除されると、2 つの POST 要求が発生しますが、これは問題ありません。
しかし、最初の POST リクエストのパラメータは
models[0][field1] 3
models[0][field2] poioioi
models[0][field3] oiuoiuuigbhkjh
models[0][field4] kjh kjhkjhyt
2 番目の POST 要求のパラメーターは次のとおりです。
models[0][field1] 3
models[0][field2] poioioi
models[0][field3] oiuoiuuigbhkjh
models[0][field4] kjh kjhkjhyt
models[1][field1] 4
models[1][field2] kjhk hkiui
models[1][field3] khkj
models[1][field4] mkhkhkhkjhghgfgdf
そして、私はこのようにサーバー内のデータにアクセスできることを理解しています
foreach ($_POST['models'] as $model) {
echo $model['field1'];
}
1回のリクエストで2行を削除できるため、1回のリクエストのみを送信できるかどうか疑問に思っていました。おそらく2番目のPOSTリクエストのみです。
または、一度に 1 つのモデルのみで 2 つの別々のリクエストを送信しますか?
出来ますか?
どんな助けでも大歓迎です。