EXTJS 4嵌套json数组数据到网格面板

时间:2013-06-13 00:08:49

标签: arrays json model extjs4 gridpanel

我是ExtJS的新手,但我无法找到用简单的JSON字符串数组填充网格。我的JSON看起来像这样:

{
 ...stuff...
 "users": ["kevin","ryan", "david", "mark", "ed"]
 ...more stuff...
}

我想用这个用户列表填充一个简单的一列网格,但似乎无法找到任何方法! :(

我的代码如下所示:

  Ext.define('usersModel', {
      extend: 'Ext.data.Model',
      fields: [{ name: 'users', type: 'auto'}]
  });

  var usersStore = Ext.create('Ext.data.Store', {
      model: 'usersModel',
      proxy: {
          type: 'ajax',
          url : '/users',
          reader: 'json'
      },
      autoLoad: true
  });

  // create the Grid
  Ext.create('Ext.grid.Panel', {
      store: usersStore,
      columns: [{
          dataIndex: 'users',
          width: 500,
          text: 'User'
      },
      ],
  });

但它只显示一个单元格中用户的逗号分隔列表。我可以看到为什么它会这样做,我将列的dataIndex设置为数组,而不是数组中的元素,但不知道如何修复它。

1 个答案:

答案 0 :(得分:1)

试试这个:

  Ext.define('usersModel', {
      extend: 'Ext.data.Model',
      fields: [{ name: 'name', type: 'auto'}]
  });

  var usersStore = Ext.create('Ext.data.Store', {
      model: 'usersModel',
      proxy: {
          type: 'ajax',
          url : '/users',
          reader: {
              type: 'json',
              rootProperty: 'users'
          }
      },
      autoLoad: true
  });

  // create the Grid
  Ext.create('Ext.grid.Panel', {
      store: usersStore,
      columns: [{
          dataIndex: 'name',
          width: 500,
          text: 'User'
      },
      ],
  });