我在Ext JS in Action(J.Garcia著)中读到,如果我们有Ext.data.Record的实例,我们可以使用表单的loadRecord方法来设置表单的值。然而,他并没有给出一个具体的例子(在他使用数据的例子中,数据是通过一个名为data.php的文件加载到表单中的)。我搜索了很多论坛,发现以下条目很有帮助,因为它让我了解了如何使用表单的loadRecord方法来解决我的问题:从网格加载数据以形成
现在我的商店和网格的代码如下:
var userstore = Ext.create('Ext.data.Store', {
storeId: 'viewUsersStore',
model: 'Configs',
autoLoad: true,
proxy: {
type: 'ajax',
url: '/user/getuserviewdata.castle',
reader: {
type: 'json',
root: 'users'
},
listeners: {
exception: function (proxy, response, operation, eOpts) {
Ext.MessageBox.alert("Error", "Session has timed-out. Please re-login and try again.");
}
}
}
});
var grid = Ext.create('Ext.grid.Panel', {
id: 'viewUsersGrid',
title: 'List of all users',
store: Ext.data.StoreManager.lookup('viewUsersStore'),
columns: [
{ header: 'Username', dataIndex: 'username' },
{ header: 'Full Name', dataIndex: 'fullName' },
{ header: 'Company', dataIndex: 'companyName' },
{ header: 'Latest Time Login', dataIndex: 'lastLogin' },
{ header: 'Current Status', dataIndex: 'status' },
{ header: 'Edit',
menuDisabled: true,
sortable: false,
xtype: 'actioncolumn',
width: 50,
items: [{
icon: '../../../Content/ext/img/icons/fam/user_edit.png',
tooltip: 'Edit user',
handler: function (grid, rowIndex, colIndex) {
var rec = userstore.getAt(rowIndex);
alert("Edit " + rec.get('username')+ "?");
EditUser(rec.get('id'));
}
}]
},
]
});
function EditUser(id) {
//I think I need to have this code here - I don't think it's complete/correct though
var formpanel = Ext.getCmp('CreateUserForm');
formpanel.getForm().loadRecord(rec);
}
"CreateUserForm"是一个已经存在的表单的ID,当用户单击"编辑"图标时应该显示该ID。然后,该弹出表单应该自动填充网格行中的正确数据。
但是,我的代码不起作用。我在"formpanel.getForm().loadRecord(rec)"行收到一个错误,上面写着"Microsoft JScript运行时错误:"undefined"为null或不是对象"。
关于如何解决这个问题,有什么建议吗?
Rec在EditUser函数中未定义。如果将ID作为参数提供给EditUser,则需要将记录作为参数提供。
//The call
EditUser(rec);
function EditUser(rec) {
var formpanel = Ext.getCmp('CreateUserForm');
formpanel.getForm().loadRecord(rec);
}