Сгруппированный и отсортированный список в sencha touch 2 - PullRequest
2 голосов
/ 08 ноября 2011

У меня следующий код

Ext.regModel('Centre', {
   fields: ['name', 'url']
}); 

Ext.application({
    name: 'Sencha',

    launch: function() {

         var panel = new Ext.Panel({
        fullscreen: true,
        dockedItems: [
          {
            xtype: "toolbar",
            dock: "top",
            title: "DEMO APP"

          },
          {
            xtype: "toolbar",
            items: [
              {
                iconMask: true,
                iconCls: "download"
              },
              {
                iconMask: true,
                iconCls: "favorites"
              },
              {
                iconMask: true,
                iconCls: "search"
              },
              {
                iconMask: true,
                iconCls: "user"
              }
            ]  
          },
          {
            xtype: 'list',
            itemTpl: '{name}',
            sorters: 'name',

            store: {
                fields: ['name', 'url'],
                   data: centers
            },
            itemConfig: {
              tpl: '{url}'
            },
            listeners: {
              itemtap:function(data,index){
                var record = data.getStore().getAt(index);
                redirect_url = record.raw.url
                 // the record that has been clicked.
                 window.location = redirect_url
              }
            }
          },


        ]
      });   


   }
});

centers есть список центров.Я хочу отсортировать и сгруппировать список.Пробовал getGroupString (), но не помогло.Может быть, я что-то упустил ..

Ответы [ 2 ]

3 голосов
/ 08 ноября 2011

В вашем списке должно быть свойство config grouped:true

(// indexBar:true as well if you want the alphabet on the side)

В вашем магазине должна быть реализована функция getGroupString

getGroupString: function(record) { return record.get('name') }
2 голосов
/ 29 июля 2013

Для тех, кто использует 2.1+, теперь синтаксис определяет групповой объект с функцией groupFn в конфигурации:

grouper: {
    groupFn: function(record) {
        return record.get('name').substr(0, 1);
    },
    sortProperty: 'name'
}
...