dxDataGrid - 如何刷新小部件
dxDataGrid - How to refresh the widget
当我单击按钮时,不起作用 refresh.If 目的是将按钮添加到数据库,按下按钮进入屏幕。但是不更新。我用 ajax 创建了一个数据网格。我也在ViewModel.What里面写了刷新功能,可能是没有更新的原因。我的数据是 json.
$.ajax({
type: "GET",
url: "https://js.devexpress.com/Demos/WidgetsGallery/data/orderItems"
success: function (msg, result, status, xhr) {
var obj = jQuery.parseJSON(msg);
$("#gridContainer").dxDataGrid({
dataSource: obj,
filterRow: {
visible: true}});}});
var viewModel = {
refresh: function () {
var dataGrid = $('#gridContainer').dxDataGrid('instance');
dataGrid.refresh();}};
return viewModel;
<div data-options="dxView : { name: 'dd',disableCache: true } " >
<div data-bind="dxCommand: { icon: 'refresh', id: 'save', onExecute: refresh }"></div>
<div data-options="dxContent : { targetPlaceholder: 'content' } " >
<div id="gridContainer"></div>
</div>
</div>
正如 Alex 提到的,您的 ajax 只发生了一次。所以,最好使用DataSource configuration object来加载数据:
var dataSource = {
load: function() {
var items = $.Deferred();
$.ajax({
type: "GET",
url: "https://js.devexpress.com/Demos/WidgetsGallery/data/orderItems",
success: function(result) {
items.resolve(result.items);
}
});
return items.promise();
}
};
$("#gridContainer").dxDataGrid({
dataSource: dataSource,
//...
});
然后,如果调用dxDataGrid的refresh()
方法,数据源将被重新加载。
注意,如果您的数据源是动态变化的,refresh 方法很有用。
当我单击按钮时,不起作用 refresh.If 目的是将按钮添加到数据库,按下按钮进入屏幕。但是不更新。我用 ajax 创建了一个数据网格。我也在ViewModel.What里面写了刷新功能,可能是没有更新的原因。我的数据是 json.
$.ajax({
type: "GET",
url: "https://js.devexpress.com/Demos/WidgetsGallery/data/orderItems"
success: function (msg, result, status, xhr) {
var obj = jQuery.parseJSON(msg);
$("#gridContainer").dxDataGrid({
dataSource: obj,
filterRow: {
visible: true}});}});
var viewModel = {
refresh: function () {
var dataGrid = $('#gridContainer').dxDataGrid('instance');
dataGrid.refresh();}};
return viewModel;
<div data-options="dxView : { name: 'dd',disableCache: true } " >
<div data-bind="dxCommand: { icon: 'refresh', id: 'save', onExecute: refresh }"></div>
<div data-options="dxContent : { targetPlaceholder: 'content' } " >
<div id="gridContainer"></div>
</div>
</div>
正如 Alex 提到的,您的 ajax 只发生了一次。所以,最好使用DataSource configuration object来加载数据:
var dataSource = {
load: function() {
var items = $.Deferred();
$.ajax({
type: "GET",
url: "https://js.devexpress.com/Demos/WidgetsGallery/data/orderItems",
success: function(result) {
items.resolve(result.items);
}
});
return items.promise();
}
};
$("#gridContainer").dxDataGrid({
dataSource: dataSource,
//...
});
然后,如果调用dxDataGrid的refresh()
方法,数据源将被重新加载。
注意,如果您的数据源是动态变化的,refresh 方法很有用。