ExtJs:等待直到存储加载,然后执行next语句
ExtJs: Wait till store loads and then execute next statements
我有一个存储,我需要加载并在存储加载后对代码中的记录执行操作。但由于执行是异步的,因此即使在store完全加载完成之前,store加载后的语句也会执行。
如何在store加载完成之前停止执行
代码如下:
var fieldsStore = new Ext.create('Ext.data.Store', {
model : 'FieldsModel',
proxy : {
type : 'ajax',
url : 'queryBuilder_getQueryDetails',
extraParams : {
queryID : queryID
},
reader : {
type : 'json'
}
},
listeners : {
load : function(store, records, successful, operation, eOpts) {
if (successful) {
records.forEach(function(rec) {
// default settings: if datatype is INTEGER - SUM
if (rec.get('fieldType') == 'INTEGER') {
rec.set('fieldSettingKey', 'SUM');
rec.set('fieldSettingValue', 'Sum');
} else {
// else select ROWHEADER by default
rec.set('fieldSettingKey', 'ROWHEADER');
rec.set('fieldSettingValue', 'Row Header');
}
});
store.commitChanges();
}
}
}
});
function loadPivotDefinition(pivotDef) {
// load query in combo
Ext.getCmp('queryListCombo').select(pivotDef.get('queryID'));
// set params as the query id to fetch fields
fieldsStore.proxy.extraParams.queryID = pivotDef.get('queryID');
// load fields store
fieldsStore.load();
// THIS IS WHERE I WANT TO CODE TO HALT AND CHECK IF THE STORE HAS COMPLETED LOADING.
// load field data (checked, data binding )
debugger;
pivotDef.get('rowHeaders').forEach(
function(rowRecord) {
var storeRecord = fieldsStore.findRecord('fieldName',
rowRecord.fieldName, 0, false, true, true);
storeRecord.set('checked', rowRecord.checked);
storeRecord.set('fieldSettingKey', rowRecord.fieldSettingKey);
storeRecord.set('fieldSettingValue',
rowRecord.fieldSettingValue);
});
}
store。Load可以接受一个回调作为参数:
fieldsStore.load(function() {
// THIS IS WHERE I WANT TO CODE TO HALT AND CHECK IF THE STORE HAS COMPLETED LOADING.
// load field data (checked, data binding )
debugger;
pivotDef.get('rowHeaders').forEach(/*...*/);
});
当你将callback作为参数传递时,callback会在数据加载后立即执行。
在某些操作中,使用以下方式加载存储:
Ext.getStore('store').load({
params: {
/* parameters to pass*/
},
callback : function(records, operation, success) {
/* perform operations on the records*/
console.log(records);
}
});
相关文章:
- jQuery-等待此元素,然后执行1次
- 方法来查看jQuery文件是否已完全加载,然后执行与其相关的函数
- 识别javascript,然后执行“;包括“;
- 首先验证表单,然后执行 Ajax 调用
- Phantomjs 检查响应标头,然后执行某些操作
- 等待多个条件,然后执行函数
- jQuery children().fadeOut() 然后执行单个函数
- jQuery是否可以用JavaScript替换文本,然后执行
- 等待几个 ajax 调用完成,然后执行某些操作
- 执行 C# 事件处理程序,然后执行该 js 函数
- JavaScript循环等待一些函数返回,然后执行下一个循环
- AG-Grid 将列标题设置为复选框,然后执行全选或取消全选列,而不是仅组
- 重新加载仅包含脚本的 DIV,然后执行脚本
- 等待几秒钟,让下载完成,然后执行PHP代码
- 使用JQuery在元素中查找文本,然后执行函数
- jQuery:检查元素是否有类,然后执行函数
- Node.js:执行多个异步操作的最佳方式,然后执行其他操作
- 将页面重定向到另一个页面,然后执行jQuery操作
- 检查是否选中任何单选按钮,然后执行代码(多组按钮)
- 加载页面,然后执行javascript