Exemplo ExtJS 4 MVC: Paging Grid

02 Apr 2012
2 mins read

Mais um exemplo MVC de ExtJS 4 aqui no blog. Hoje vamos ver o código do exemplo Paging Grid.

Vamos ao código então!

Estrutura do Projeto


[code lang="js" firstline="1" toolbar="true" collapse="false" wraplines="false"]
Ext.define('ExtMVC.model.ForumThread', {
extend: 'Ext.data.Model',
fields: [
{name: 'replycount', type: 'int'},
{name: 'lastpost', mapping: 'lastpost', type: 'date', dateFormat: 'timestamp'},
idProperty: 'threadid'


[code lang="js" firstline="1" toolbar="true" collapse="false" wraplines="false"]
Ext.define('ExtMVC.store.ForumThreads', {
extend: 'Ext.data.Store',
model: 'ExtMVC.model.ForumThread',
autoLoad: true,
remoteSort: true,
proxy: {
// load using script tags for cross domain, if the data in on the same domain as
// this page, an HttpProxy would be better
type: 'jsonp',
url: 'http://www.sencha.com/forum/topics-browse-remote.php',
reader: {
root: 'topics',
totalProperty: 'totalCount'
// sends single sort as multi parameter
simpleSortMode: true
sorters: [{
property: 'lastpost',
direction: 'DESC'

View - Grid

[code lang="js" firstline="1" toolbar="true" collapse="false" wraplines="false"]
Ext.define('ExtMVC.view.forumThread.ForumThreadGrid' ,{
extend: 'Ext.grid.Panel',
alias : 'widget.forumthreadgrid',

requires: 'Ext.ux.PreviewPlugin',

title : 'ExtJS.com - Browse Forums',

disableSelection: true,

loadMask: true,

viewConfig: {
id: 'gv',
trackOver: false,
stripeRows: false,
plugins: [{
ptype: 'preview',
bodyField: 'excerpt',
expanded: true,
pluginId: 'preview'

// pluggable renders
renderTopic: function(value, p, record) {
return Ext.String.format(
'<strong><a href="http://sencha.com/forum/showthread.php?t={2}" target="_blank">{0}</a></strong><a href="http://sencha.com/forum/forumdisplay.php?f={3}" target="_blank">{1} Forum</a>',

renderLast: function(value, p, r) {
return Ext.String.format('{0}
by {1}', Ext.Date.dateFormat(value, 'M j, Y, g:i a'), r.get('lastposter'));

initComponent: function() {

this.store = 'ForumThreads';

this.columns = [
id: 'topic',
text: "Topic",
dataIndex: 'title',
flex: 1,
renderer: this.renderTopic,
sortable: false
text: "Author",
dataIndex: 'username',
width: 100,
hidden: true,
sortable: true
text: "Replies",
dataIndex: 'replycount',
width: 70,
align: 'right',
sortable: true
id: 'last',
text: "Last Post",
dataIndex: 'lastpost',
width: 150,
renderer: this.renderLast,
sortable: true

// paging bar on the bottom
this.bbar = Ext.create('Ext.PagingToolbar', {
store: this.store,
displayInfo: true,
displayMsg: 'Displaying topics {0} - {1} of {2}',
emptyMsg: "No topics to display",
'-', {
xtype: 'button',
text: 'Show Preview',
pressed: true,
action: 'showPreview',
enableToggle: true


View- Viewport

[code lang="js" firstline="1" toolbar="true" collapse="false" wraplines="false"]
* The main application viewport, which displays the whole application
* @extends Ext.Viewport
Ext.define('ExtMVC.view.Viewport', {
extend: 'Ext.Viewport',
layout: 'fit',

requires: [

initComponent: function() {
var me = this;

Ext.apply(me, {
items: [
xtype: 'forumthreadgrid'



[code lang="js" firstline="1" toolbar="true" collapse="false" wraplines="false"]
Ext.define('ExtMVC.controller.ForumThreads', {
extend: 'Ext.app.Controller',

stores: ['ForumThreads'],

models: ['ForumThread'],

views: ['forumThread.ForumThreadGrid'],

init: function() {
'forumthreadgrid button[action=showPreview]': {
toggle: this.showPreview

showPreview: function(btn, pressed){

var preview = Ext.ComponentQuery.query('forumthreadgrid dataview')[0].plugins[0];



[code lang="js" firstline="1" toolbar="true" collapse="false" wraplines="false"]
name: 'ExtMVC',

paths: { 'Ext.ux': 'extjs/ux/' },

controllers: [

autoCreateViewport: true

Página HTML

[code lang="html" firstline="1" toolbar="true" collapse="false" wraplines="false"]
<title>Ext JS 4 MVC Examples - loiane.com</title>

<link rel="stylesheet" type="text/css" href="extjs/resources/css/ext-all.css">

.x-grid-cell-topic b {
display: block;
.x-grid-cell-topic .x-grid-cell-inner {
white-space: normal;
.x-grid-cell-topic a {
color: #385F95;
text-decoration: none;
.x-grid-cell-topic a:hover {
.x-grid-cell-topic .x-grid-cell-innerf {
padding: 5px;
.x-grid-rowbody {
padding: 0 5px 5px 5px;

<script type="text/javascript" src="extjs/ext-debug.js"></script>

<script type="text/javascript" src="app.js"></script>


Download do código fonte completo

Você pode fazer o download do código fonte completo através dos meu repositório do Github: https://github.com/loiane/extjs4-mvc-paging-grid


Para ver esse projeto rodando, acesse o link: https://loiane.com/extjs/extjs4-mvc-paging-grid/

Até o próximo exemplo! :)