0
votes

I created a grid using the following code.

<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%>
<div id="grid-wrapper" style="margin: 5px 5px;height: calc(100% - 10px)">
    <div class="k-content" id="grid">

    </div>
</div>
<script type="text/x-kendo-template" id="fts">
    <input type="search" id="search" class="k-input k-textbox" style="width: 150px" />
</script>   
<script>
    // 数据源
    var crudServiceBaseUrl = "data/infra/roles";
    var ds_options = {
        url: crudServiceBaseUrl,
        dataType: "json",
        contentType : 'application/json; charset=UTF-8',
        type : 'POST'
    };
    var dataSource = new kendo.data.DataSource({
        transport: {
            read:  ds_options,
            update: ds_options,
            destroy: ds_options,
            create: ds_options,
            parameterMap: function(options, operation) {
                options.action = operation;
                return kendo.stringify(options);
            }
        },
        batch: true,
        pageSize: 10,
        serverPaging : true,
        serverFiltering : true,
        serverSorting : true,
        schema: {
            total : "total",
            data : "data",
            model: {
                id: "roleID",
                fields: {
                    roleID: { editable: true, nullable: false },
                    sortNo: { validation: { required: true } },
                    roleName: { validation: { required: true } },
                    roleStatus: { },
                    allocated: {type : 'number' }
                }
            }
        },
        requestEnd : function(e){
            console.log('request end of role grid');
        },
        error : function(e){
            console.log('error happened:' + e.errors);
        }
    });

    function edit(){
        alert('edit');
    }

    var grid = $("#grid").kendoGrid({
        dataSource : dataSource,
        toolbar : [{
            text: "新增",
            imageClass: "k-add",
            className: "k-grid-add",
            iconClass: "k-icon",
            click : function(e){
                alert('add');
            }
        },{
            text: "编辑",
            imageClass: "k-edit",
            className: "a-g-e",
            iconClass: "k-icon",
        },{
            text: "删除",
            imageClass: "k-delete",
            className: "a-g-d",
            iconClass: "k-icon"
        },{
            template : $("#fts").html()
        }],
        height : '100%',
        pageable: true,
        columns: [
            { field:"roleID", title: "角色编号", visible : false},
            { field:"sortNo", title: "排序号"},
            { field:"roleName", title: "角色名称"},
            { 
                field:"roleStatus", 
                title: "角色状态",
                filterable: {
                    ui: statusFilter
                }
            },
            { field:"allocated", title: "已分配用户数"}
        ],
        editable: "popup",
        resizable: true,
        selectable : "row",
        sortable : true,
        filterable: {
            extra : false,
            messages: {
                info: "查询条件:", // sets the text on top of the filter menu
                filter: "查询", // sets the text for the "Filter" button
                clear: "清除", // sets the text for the "Clear" button

                // when filtering boolean numbers
                isTrue: "是", // sets the text for "isTrue" radio button
                isFalse: "否", // sets the text for "isFalse" radio button

                //changes the text of the "And" and "Or" of the filter menu
                and: "且",
                or: "或"
            },
            operators: {
                //filter menu for "string" type columns
                string: {
                    eq: "等于",
                    neq: "不等于",
                    startswith: "以……开始",
                    contains: "包含……",
                    endswith: "以……结束"
                },
                //filter menu for "number" type columns
                number: {
                    eq: "等于",
                    neq: "不等于",
                    gte: "大于等于",
                    gt: "大于",
                    lte: "小于等于",
                    lt: "小于"
                },
                //filter menu for "date" type columns
                date: {
                     eq: "等于",
                    neq: "不等于",
                    gte: "大于等于",
                    gt: "大于",
                    lte: "小于等于",
                    lt: "小于"
                },
                //filter menu for foreign key values
                enums: {
                    eq: "等于",
                    neq: "不等于"
                }
            },
        },
        navigatable : false,
        reorderable : true,
        columnMenu: {
            messages: {
                sortAscending: "升序排列",
                sortDescending: "降序排列",
                filter: "过滤条件",
                columns: "选择列"
            }
        }
    }).data('kendoGrid');

    function statusFilter(ele){
         ele.kendoDropDownList({
             dataTextField: "text",
             dataValueField: "value",
             dataSource: [{text : "正常", value : "1"}, {text : "停用", value : "2"}],
             optionLabel: "--Select Value--"
         });
    }

    $('.a-g-e', '#grid').bind('click', function(e){
        grid.editRow(grid.select());
    });

    $('.a-g-d', '#grid').bind('click', function(e){
        grid.removeRow(grid.select());
    });
</script>
<style scoped>
.k-dropdown-wrap {
    margin-bottom : 2px
}
</style>

Each time I click the add or edit button, the default popup window appears with an "update" button; when I'm finished editing and click the update button, the modification goes to server immediately. How can I make it just save changes to local datasource and only send changes to server when the user clicks a "save" button?

In the batch edit example on Kendoui website, I found that if the changes include create, update, and delete, then more than one HTTP request is sent to server. As I use just one Java servlet to handle all CRUD operations, how can I make the Kendo grid always send only one HTTP request when doing batch updates?

1
I know this is late, and you've probably seen other posts around this: Look at the following post for some help if you still need it: stackoverflow.com/questions/17033025/…Robert Achmann

1 Answers

0
votes

this is the way that kendo works. when you use :

grid.editRow(grid.select());

it automatically uses your update method you should write your own code with ajax if you want to control all process