Ext.data.reader.Reader
Readers通常用于翻译数据,使其被加载为 Model 实例或Store, 该数据一般是一个AJAX请求的响应数据. 一般情况下不需要直接创建一个Reader实例, 因为Reader总是和Proxy一起使用, 且其将使用Proxy的reader 配置属性配置
1
2
3
4
5
6
7
8
9
10
11
|
Ext.create( 'Ext.data.Store' , {
model: 'User' ,
proxy: {
type: 'ajax' ,
url : 'users.json' ,
reader: {
type: 'json' ,
root: 'users'
}
},
}); |
以上的reader是配置来消耗一个JSON字符串,使其开起来如下:
1
2
3
4
5
6
7
|
{ "success" : true ,
"users" : [
{ "name" : "User 1" },
{ "name" : "User 2" }
]
} |
加载嵌套数据
根据每个模型上的associations配置,Readers拥有自动加载多级嵌套的数据对象的能力. 以下是一个例子,用于验证一个虚构的CRM系统(管理了User、Orders、OrderItems、Products等模型)中的各种结合的灵活性。 首先我们要定义这些模型:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
|
Ext.define( "User" , {
extend: 'Ext.data.Model' ,
fields: [
'id' , 'name'
],
hasMany: {model: 'Order' , name: 'orders' },
proxy: {
type: 'rest' ,
url : 'users.json' ,
reader: {
type: 'json' ,
root: 'users'
}
}
}); Ext.define( "Order" , {
extend: 'Ext.data.Model' ,
fields: [
'id' , 'total'
],
hasMany : {model: 'OrderItem' , name: 'orderItems' , associationKey: 'order_items' },
belongsTo: 'User'
}); Ext.define( "OrderItem" , {
extend: 'Ext.data.Model' ,
fields: [
'id' , 'price' , 'quantity' , 'order_id' , 'product_id'
],
belongsTo: [ 'Order' , {model: 'Product' , associationKey: 'product' }]
}); Ext.define( "Product" , {
extend: 'Ext.data.Model' ,
fields: [
'id' , 'name'
],
hasMany: 'OrderItem'
}); |
这个可能有很多种理解 - 基本上,一个Usrer拥有多个Orders,而每个Orders是由多个OrderItems组成的。 最后,每个OrderItem都包含单独一个Product. 这就允许我们重构造数据如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
|
{ "users" : [
{
"id" : 123,
"name" : "Ed" ,
"orders" : [
{
"id" : 50,
"total" : 100,
"order_items" : [
{
"id" : 20,
"price" : 40,
"quantity" : 2,
"product" : {
"id" : 1000,
"name" : "MacBook Pro"
}
},
{
"id" : 21,
"price" : 20,
"quantity" : 3,
"product" : {
"id" : 1001,
"name" : "iPhone"
}
}
]
}
]
}
]
} |
该JSON响应就是多级嵌套- 将返回所有的Users(在本例中为简单起见,只写了一个User), 每个User中的Orders的所有项(一样只写其中一个为例), 每个Order中的OrderItems的所有项(本例中显示了2个order项),最后Product通过每个OrderItem关联在一起. 现在我们可以读取数据并使用它通过如下方式:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
|
var store = Ext.create( 'Ext.data.Store' , {
model: "User"
}); store.load({ callback: function () {
//被加载的user
var user = store.first();
console.log( "Orders for " + user.get( 'name' ) + ":" )
//遍历每个User中的Orders
user.orders().each( function (order) {
console.log( "Order ID: " + order.getId() + ", which contains items:" );
//遍历每个Order中的OrderItems
order.orderItems().each( function (orderItem) {
//我们都知道Product数据已经被加载,所以我们可以使用同步方法getProduct
//一般来说,我们会使用异步版本的 (参考 Ext.data.association.BelongsTo)
var product = orderItem.getProduct();
console.log(orderItem.get( 'quantity' ) + ' orders of ' + product.get( 'name' ));
});
});
}
}); |
运行以上代码,结果如下:
1
2
3
4
|
Orders for Ed:
Order ID: 50, which contains items: 2 orders of MacBook Pro 3 orders of iPhone |