2

我正在使用 Extjs 4.2,并且我的页面上有一个组合框字段。当我更新此页面时,我需要在组合框中显示选定的值。如果我使用静态数据,它将正常工作,但是当我从数据库加载数据时,数据即将到来,但它显示所选组合框的值(而不是标签)。

我已经通过使用select组合框的方法完成了工作,但是我需要迭代存储以获取所选值。存储值不是从 1 开始而是从 100 开始,select组合框的方法使用列表的索引。

以下是您可以检查的代码,但这不适用于多个组合框。

var specilizationComboBox = Ext.getCmp("doctorMasterVO.specilizationFkId");

var specilizationValue = 0;

specilizationStore.each(function (record) {
    if (record.get('value') != dataRead.dataVO.doctorMasterVO.specilizationFkId) {
        specilizationValue = specilizationValue + 1;
    }
    else {
        return false; 
    }
});

specilizationComboBox.select(specilizationComboBox.store.data.items[specilizationValue]);

请告诉我还有其他方法可以做到这一点,因为迭代整个商店不是一个好主意。

4

1 回答 1

0

看看这些方法:

寻找

查找依据

查找记录

查找准确

基本上你想要做的是这样的:

var myId = dataRead.dataVO.doctorMasterVO.specilizationFkId;
var record = store.findRecord("id", myId);
specilizationComboBox.select(record);

其中“id”是您尝试在商店中查找匹配的字段的名称。请注意,如果记录不存在或存储未正确加载,则 myRecord 可能为空。

为了确保商店已加载,您可以在加载处理程序中执行上面的代码:

specilizationComboBox.getStore().load({
    scope: this,
    callback: function(records, operation, success) {
      //code goes here
    }
});

如果您不确定商店是否已加载,您可以检查getCount方法。

于 2013-07-08T08:00:40.957 回答