在使用Ext与DWR框架时,我们往往会用到GridPanel组件搭配PagingToolbar组件来实现翻页数据列表。翻页的时候每一页都要从后台获取该页的数据列表信息。
在解决此问题时,花了不少时间,看过不少前人的代码,终于成功了!共享之。
关键代码如下:
Store为:
1data:image/s3,"s3://crabby-images/16507/1650758e64773369e558bf6a35239aa629f2eb9d" alt=""
var ds = new Ext.data.Store(
{
2data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
3data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
proxy: new Ext.data.DWRProxy(
{
4
callback: Folder.getMessageList,
5data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
params:
{
6
start: '0',
7
limit: PAGE_SIZE
8
}
9
}),
10
11
// proxy: new Ext.data.MemoryProxy(messageList),
12
13data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
reader: new Ext.data.ObjectReader(
{
14
root: 'messages',
15
totalProperty: 'total'//用来让Ext的PagingToolbar组件分析总页数
16data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
}, [
{
17
name: 'messageId'
18data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
},
{
19
name: 'from'
20data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
},
{
21
name: 'subject'
22data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
},
{
23
name: 'sendTime'
24data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
},
{
25
name: 'contentText'
26
}])
27data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
28
});
29data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
30
//在进行DWR请求之前,默认在请求参数中添加当前文件夹ID。这样DWR请求中包括的请求参数为:folderId,start,limit
31data:image/s3,"s3://crabby-images/16507/1650758e64773369e558bf6a35239aa629f2eb9d" alt=""
ds.on('beforeload', function()
{
32data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
Ext.apply(this.baseParams,
{
33
folderId: currentFolderId
34
});
35
});
36data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
37data:image/s3,"s3://crabby-images/16507/1650758e64773369e558bf6a35239aa629f2eb9d" alt=""
ds.load(
{
38data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
params:
{
39
start: currentStart,
40
limit: currentLimit
41
}
42
});//指定起始位置以及个数
自定义的DWRProxy和ObjectReader:
1data:image/s3,"s3://crabby-images/16507/1650758e64773369e558bf6a35239aa629f2eb9d" alt=""
Ext.data.DWRProxy = function(config)
{
2
Ext.data.DWRProxy.superclass.constructor.call(this);
3
Ext.apply(this, config ||
4data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
{});
5
};
6data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
7data:image/s3,"s3://crabby-images/16507/1650758e64773369e558bf6a35239aa629f2eb9d" alt=""
Ext.extend(Ext.data.DWRProxy, Ext.data.DataProxy,
{
8
//DWR请求
9data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
load: function(params, reader, callback, scope, arg)
{
10
currentStart = params.start;//保存当前页记录起始位置
11
currentLimit = params.limit;//保存当前页记录的个数
12data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
document.dwr =
{
13
params: params,
14
reader: reader,
15
callback: callback,
16
scope: scope,
17
arg: arg
18
};
19
//处理请求参数,将各个请求参数转换到Array中
20
var callParams = new Array();
21
callParams.push(params.folderId);//当前文件夹ID
22
callParams.push(params.start);//请求的起始位置
23
callParams.push(params.limit);//请求的个数
24data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
if (this.params !== undefined && this.params !== null)
{
25
this.callback.call(this, callParams, this.loadResponse);//DWR请求
26
}
27data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
else
{
28
this.callback.call(this, this.loadResponse);
29
}
30
},
31
//处理DWR返回
32data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
loadResponse: function(response)
{
33
var dwr = document.dwr;
34data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
try
{
35
//IE throws an exception 'Error: TypeError, Object does not support this operation'
36
//so use try
catch
to suppress this exception
37
delete document.dwr;//ie不支持delete
38
}
39data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
catch (e)
{
40
}
41
var result;
42data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
try
{
43
result = dwr.reader.read(response);//读取请求返回的json
44
}
45data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
catch (e)
{
46
//this.fireEvent("loadexception",this,dwr,response,e);
47
dwr.callback.call(dwr.scope, null, dwr.arg, false);
48
return;
49
}
50
dwr.callback.call(dwr.scope, result, dwr.arg, true);
51
},
52data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
failure: function(errorString, exception)
{
53
console.log("DWR " + exception);
54
},
55data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
update: function(params, records)
{
56
}
57
});
58data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
59
//自定义一个用于处理返回消息列表的Reader
60data:image/s3,"s3://crabby-images/16507/1650758e64773369e558bf6a35239aa629f2eb9d" alt=""
Ext.data.ObjectReader = function(meta, recordType)
{
61
Ext.data.ObjectReader.superclass.constructor.call(this, meta, recordType);
62
};
63data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
64data:image/s3,"s3://crabby-images/16507/1650758e64773369e558bf6a35239aa629f2eb9d" alt=""
Ext.extend(Ext.data.ObjectReader, Ext.data.DataReader,
{
65
//处理DWR返回
66data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
read: function(response)
{
67
var responseDecode = Ext.util.JSON.decode(response);//注意,由java的json-lib生成的json串需要解码一下
68
var data = responseDecode.messages;
69
var sid = this.meta ? this.meta.id : null;
70
var recordType = this.recordType, fields = recordType.prototype.fields;
71
var records = [];
72
var root = data;
73data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
for (var i = 0; i < root.length; i++)
{
74
var obj = root[i];
75data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
var values =
{};
76
var id = obj[sid];
77data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
for (var j = 0, jlen = fields.length; j < jlen; j++)
{
78
var f = fields.items[j];
79
var k = (f.mapping !== undefined && f.mapping !== null) ? f.mapping : f.name;
80
var v = null;
81
var idx = k.indexOf(".");
82data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
if (idx == -1)
{
83
v = obj[k] !== undefined ? obj[k] : f.defaultValue;
84
}
85data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
else
{
86
var k1 = k.substr(0, idx);
87
var k2 = k.substr(idx + 1);
88data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
if (obj[k1] == undefined)
{
89
v = f.defaultValue;
90
}
91data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
else
{
92
var obj2 = obj[k1];
93
v = obj2[k2] !== undefined ? obj2[k2] : f.defaultValue;
94
}
95
}
96
v = f.convert(v);
97
values[f.name] = v;
98
}
99
var record = new recordType(values, id);
100
records[records.length] = record;
101
}
102data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
return
{
103
records: records,//返回的消息列表记录
104
totalRecords: responseDecode.total//总个数
105
};
106
}
107
});
--------------------
WE准高手
posted on 2008-03-20 13:51
大卫 阅读(6938)
评论(1) 编辑 收藏 所属分类:
Java 、
JavaScript