从书中看到这个通过重写Ext.data.Store的applySort函数实现Grid支持中文排序,摘抄下来。以备不时之需。
1data:image/s3,"s3://crabby-images/16507/1650758e64773369e558bf6a35239aa629f2eb9d" alt=""
Ext.data.Store.prototype.applySort = function()
{
2data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
if(this.sortInfo && !this.remoteSort)
{
3
var s = this.sortInfo, f = s.field;
4
var st = this.fields.get(f).sortType;
5data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
var fn = function(r1,r2)
{
6
var v1 = st(r1.data[f]),v2 = st(r2.data[f]);
7data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
if(typeof(v1)=="string")
{
8
return v1.localeCompare(v2);
9
}
10
return v1 > v2 ?1:(v1 < v2?-1:0);
11
};
12
this.data.sort(s.direction, fn);
13data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
if(this.snapshot && this.snapshot != this.data)
{
14
this.snapshot.sort(s.direction,fn);
15
}
16
}
17
}
这段代码可以放在ext-all.js文件的最后,或放到html页面的最上面。主要是要在EXT初始化之后,实际代码调用之前执行。
附例如下:
1
<html>
2
<head>
3
<meta http-equiv="Content-Type" content="text/html; charset=gbk">
4
<title>03.grid</title>
5
<link rel="stylesheet" type="text/css" href="../../resources/css/ext-all.css" />
6
<script type="text/javascript" src="../../adapter/ext/ext-base.js"></script>
7
<script type="text/javascript" src="../../ext-all.js"></script>
8data:image/s3,"s3://crabby-images/16507/1650758e64773369e558bf6a35239aa629f2eb9d" alt=""
<script type="text/javascript">data:image/s3,"s3://crabby-images/87db9/87db9337486e6758d772829a26342839bc8c1a52" alt=""
9data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
Ext.data.Store.prototype.applySort = function()
{
10data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
if (this.sortInfo && !this.remoteSort)
{
11
var s = this.sortInfo, f = s.field;
12
var st = this.fields.get(f).sortType;
13data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
var fn = function(r1, r2)
{
14
var v1 = st(r1.data[f]), v2 = st(r2.data[f]);
15data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
if (typeof(v1) == "string")
{
16
return v1.localeCompare(v2);
17
}
18
return v1 > v2 ? 1 : (v1 < v2 ? -1 : 0);
19
};
20
this.data.sort(s.direction, fn);
21data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
if(this.snapshot && this.snapshot != this.data)
{
22
this.snapshot.sort(s.direction, fn);
23
}
24
}
25
};
26data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
27data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
28data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
Ext.onReady(function()
{
29data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
30
var cm = new Ext.grid.ColumnModel([
31data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
{header:'编号',dataIndex:'id',sortable:true,width:35},
32data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
{header:'名称',dataIndex:'name',sortable:true,width:80},
33data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
{id:'descn',header:'描述',dataIndex:'descn',sortable:true,width:200}
34
]);
35data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
36
var data = [
37
['1','啊','descn1'],
38
['2','啵','descn2'],
39
['3','呲','descn3'],
40
['4','嘚','descn4'],
41
['5','咯','descn5']
42
];
43data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
44data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
var store = new Ext.data.Store(
{
45
proxy: new Ext.data.MemoryProxy(data),
46data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
reader: new Ext.data.ArrayReader(
{}, [
47data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
{name: 'id'},
48data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
{name: 'name'},
49data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
{name: 'descn'}
50
]),
51data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
sortInfo:
{field: "name", direction: "ASC"}
52
});
53
store.load();
54data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
55data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt=""
var grid = new Ext.grid.GridPanel(
{
56
autoHeight: true,
57
renderTo: 'grid',
58
store: store,
59
cm: cm,
60
autoExpandColumn: 'descn'
61
});
62data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
63
});
64
</script>
65
</head>
66
<body>
67
<script type="text/javascript" src="../examples.js"></script>
68
<div id="grid"></div>
69
</body>
70
</html>
71data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""