1

对于我的 Kendo 数据源,生成的 json 有一列“TotalRecords”,我如何将这个总数设置为 Kendo 数据源总数,以便我的服务器分页可以工作。我的代码如下:

 var iDataSource = new kendo.data.DataSource({
            transport: {
                read:
                    {
                        url: service_URL + "GetUnconfirmedppointments",
                        datatype: "json",
                        type: "GET"
                    },
                parameterMap: function (options) {
                    return {
                        appointmentNos: Appointment_Number.value,
                        loadNumbers: Load_Number.value,
                        purchaseOrders: Purchase_Orders.value,
                        dateFrom: Date_From.value,
                        dateTo: Date_To.value,
                        warehouse: warehouses.value,
                        carrierId: cr_carrier_id,
                        sortColum: getOrderBy(options.sort),
                        sortDirection: getOrderDir(options.sort),
                        pageSize: options.pageSize,
                        pageNumber: options.page
                    };
                }
            },
            schema: {
                model: {
                    fields: {
                        APP_APPOINTMENT_ID: { type: "number" },
                        APPOINTMENT_DATE: { type: "date" },
                        LO_LOAD_NUMBER: { type: "number" }
                    }
                }
            },
            pageSize: 5,
            total: function (response) {
               return response[0].TotalRecords;
            },
            serverPaging: true,
            serverFiltering: true,
            serverSorting: true
        });

当前实现不起作用,即使我提供了硬编码的总记录数,当此数据源绑定到网格时,总计数仅显示 json 中返回的记录数,即 pagesize。

4

2 回答 2

6

我假设您的总数在每条记录上?如果不是,你可以这样做...

schema: {
  total: "TotalRecords"
}

理想情况下,您的 JSON 应该是这样的结构......

{ data:[...], total: 100 }

但是,如果您不能像这样从服务器发送模式,则可以解析模式。如果总计数附加到每条记录,您可以添加一个字段来保存它并在解析中填充它。

schema: {
  parse: function(data) {
      // assign top level array to property
      data.data = data;
      // assign the count off one of the fields to a new total field
      data.total = data.data[0].TotalRecords;

      return data;
  }
}
于 2013-02-06T22:22:01.950 回答
2

As my response has total records fields with each record therefore I just moved the below into schema and it fixed it.

total: function (response) { return response[0].TotalRecords; }
于 2013-02-07T19:56:32.127 回答