需要将ExtJs示例应用程序转换为MVC应用程序

时间:2012-06-01 13:58:39

标签: extjs extjs4 extjs-mvc

我对此示例有疑问请参阅此链接 http://dev.sencha.com/deploy/ext-4.0.0/examples/grid/buffer-grid.html

我想转换MVC应用程序。所以有人请帮助我。

1 个答案:

答案 0 :(得分:11)

首先是你的app / model文件夹中的模型

Ext.define('AppName.model.Employee', {
    extend: 'Ext.data.Model',
    fields: [
       {name: 'rating', type: 'int'},
       {name: 'salary', type: 'float'},
       {name: 'name'}
    ]
});

并存储在您的app / store文件夹中

Ext.define('AppName.store.Employee', {
    extend:'Ext.data.Store', 
    buffered: true,
    pageSize: 5000, 
    model: 'Employee',
    proxy: { type: 'memory' }
});

您的应用/视图文件夹中的网格视图

Ext.define('AppName.view.EmployeeGrid', {
    alias:'employeegrid',
    extend:'Ext.grid.Panel', 
    width: 700,
    height: 500,
    title: 'Bufffered Grid of 5,000 random records',
    store: 'Employee',
    loadMask: true,
    disableSelection: true,
    viewConfig: { trackOver: false }, 
    columns:[{
        xtype: 'rownumberer',
        width: 40,
        sortable: false
    },{
        text: 'Name',
        flex:1 ,
        sortable: true,
        dataIndex: 'name'
    },{
        text: 'Rating',
        width: 125,
        sortable: true,
        dataIndex: 'rating'
    },{
        text: 'Salary',
        width: 125,
        sortable: true,
        dataIndex: 'salary',
        align: 'right',
        renderer: Ext.util.Format.usMoney
    }]
}); 

您的app / controller文件夹中的控制器

Ext.define('AppName.controller.Employee',{
    extend:'Ext.app.Controller',
    stores:['Employee'],
    views:['EmployeeGrid'],
    refs:[
        {ref:'employeeGrid',selector:'employeegrid'}        
    ],
    init:function(){
        var me = this;
        me.getEmployeeStore().loadData(me.createFakeData(5000));        
    },
    createFakeData:function(count) {
        var firstNames   = ['Ed', 'Tommy', 'Aaron', 'Abe', 'Jamie', 'Adam', 'Dave', 'David', 'Jay', 'Nicolas', 'Nige'],
            lastNames    = ['Spencer', 'Maintz', 'Conran', 'Elias', 'Avins', 'Mishcon', 'Kaneda', 'Davis', 'Robinson', 'Ferrero', 'White'],
            ratings      = [1, 2, 3, 4, 5],
            salaries     = [100, 400, 900, 1500, 1000000];

        var data = [];
        for (var i = 0; i < (count || 25); i++) {
            var ratingId    = Math.floor(Math.random() * ratings.length),
                salaryId    = Math.floor(Math.random() * salaries.length),
                firstNameId = Math.floor(Math.random() * firstNames.length),
                lastNameId  = Math.floor(Math.random() * lastNames.length),

                rating      = ratings[ratingId],
                salary      = salaries[salaryId],
                name        = Ext.String.format("{0} {1}", firstNames[firstNameId], lastNames[lastNameId]);

            data.push({
                rating: rating,
                salary: salary,
                name: name
            });
        }
        return data;
    }         
});

有趣的是,你必须在app文件夹中创建App

Ext.application({
    requires:[
        'Ext.grid.*',
        'Ext.data.*',
        'Ext.util.*',
        'Ext.grid.PagingScroller',
        'AppName.view.EmployeeGrid'
    ],
    name:'AppName', 
    models:['Employee'], 
    stores:['Employee'],
    controllers:['Employee'],
    launch:function () {
        Ext.onReady(function(){
              Ext.create('Ext.Viewport', {
                  layout: 'fit',
                  items:[{xtype:'emplyeegrid'}]
              });
        });    
    }
 });