dojo 的 Datagrid 的一个简单模板如下,我正在为更复杂的东西构建它。
例如,如何根据同一行的 field1 的 onChange 事件更新 field2 的值?就像将 field1 的值复制到 field2 一样。问题是我没有特定单元格的 id,将 onChange 放在 layout 或 addRow() 下似乎都不正确,并且似乎 onChange: function(){...} 不能使用?
/*set up data store*/
var data = {
identifier: "id",
items: []
};
var store = new dojo.data.ItemFileWriteStore({data: data});
/*set up layout*/
var layout = [
defaultCell: {
editable: true,
type: dojox.grid.cells._Widget
}
rows: [
{name: 'ID', field: 'id', width: '30px', widgetClass: dijit.form.TextBox, editable: false},
{name: 'ColA', field: 'field1', width: '100px', widgetClass: dijit.form.TextBox},
{name: 'ColB', field: 'field2', width: '100px', widgetClass: dijit.form.TextBox}
]
];
/*create a new grid*/
var grid = new dojox.grid.DataGrid({
id: 'grid',
store: store,
structure: layout,
singleClickEdit: true,
rowSelector: '15px'});
/*append the new grid to the div*/
grid.placeAt("gridDiv");
/*Call startup() to render the grid*/
grid.startup();
function addRow(){
store.newItem({
id: grid.rowCount,
field1: '-',
field2: '-'});
grid.render();
}