Ext.data.DataReader
純虛類,從數(shù)據(jù)源得到結(jié)構(gòu)化數(shù)據(jù)轉(zhuǎn)換為元數(shù)據(jù)對象,對象包含Record的集合,一般用做Store對象的元數(shù)據(jù),
具有如下格式
{
totalRecord:int,
records:Array of Ext.data.Record
}
具體使用參見三個(gè)子類
Ext.data.ArrayReader/Ext.data.JsonReader/Ext.data.XmlReader
方法
DataReader( Object meta, Object recordType )
構(gòu)造
Ext.data.ArrayReader
用于讀數(shù)組到一個(gè)元數(shù)據(jù)對象
ArrayReader( Object meta, Object recordType )
構(gòu)造,第一個(gè)參數(shù)是配置除了可以指示使用哪個(gè)字段做id外,不懂其它的用法,
第二個(gè)參數(shù)是recordType與record對象的create方法的參數(shù)一樣,是一樣config對象數(shù)組,具體參見
readRecords( Object o ) : Object
讀取o,返回一個(gè)元數(shù)據(jù)對象
用例示范:
//定義數(shù)組
var arr=[ [1, 'Bill', 'Gardener'], [2, 'Ben', 'Horticulturalist'] ];
var reader = new Ext.data.ArrayReader(
//以第一個(gè)元素做為recordid
{id: 0},
//定義數(shù)組到record的映射關(guān)系
[
{name: 'name', mapping: 1},
{name: 'occupation', mapping: 2}
]
);
//生成元數(shù)據(jù)
var data=reader.readRecords(arr);
Ext.data.JsonReader
用于將一個(gè)json對象轉(zhuǎn)換為元數(shù)據(jù)對象
JsonReader( Object meta, Object recordType )
JsonReader的構(gòu)造參數(shù)meta可以有更多選擇,
{
id : String,
root : String,
successProperty : String,
totalProperty : String
}
都是對應(yīng)json對象的屬性名
read( Object response ) : Object
從一個(gè)response對象返回,response.responseText屬性應(yīng)僅含有一個(gè)json格式數(shù)據(jù)塊
readRecords( Object o ) : Object
讀取o,返回一個(gè)元數(shù)據(jù)對象
使用示例:
var json={ 'results': 2, 'rows': [
{ 'id': 1, 'name': 'Bill', occupation: 'Gardener' },
{ 'id': 2, 'name': 'Ben', occupation: 'Horticulturalist' } ]
};
var reader=new Ext.data.JsonReader(
{
totalProperty: "results",//totalRecords屬性由json.results得到
root: "rows", //構(gòu)造元數(shù)據(jù)的數(shù)組由json.rows得到
id: "id" //id由json.id得到
},[
{name: 'name', mapping: 'name'},
{name: 'occupation'} //如果name與mapping同名,可以省略mapping
]
)
var data=reader.readRecords(json);
Ext.data.XmlReader
xmlreader對象當(dāng)然是為xml而準(zhǔn)備的
構(gòu)造:
XmlReader( Object meta, Mixed recordType )
meta與jsonreader類似,
meta是一個(gè){
id : String,
record : String,
success : String,
totalRecords : String
}對象,只是這些字符串都是相對于文檔根目錄的domquery路徑
read( Object response ) : Object
readRecords( Object doc ) : Object
....
var str=["<?xml version=\"1.0\" encoding=\"utf-8\" ?>",
"<dataset>",
"<results>2</results>",
"<row>",
"<id>1</id>",
"<name>Bill</name>",
"<occupation>Gardener</occupation>",
"</row>",
"<row>",
"<id>2</id>",
"<name>Ben</name>",
"<occupation>Horticulturalist</occupation>",
"</row>",
"</dataset>"].join("");
//生成xmldocument對象
var xmlDocument;
if(Ext.isIE){
xmlDocument = new ActiveXObject("Msxml2.FreeThreadedDOMDocument")
xmlDocument.async=false;
xmlDocument.resolveExternals = false;
xmlDocument.loadXML(str)
}
else{
xmlDocument = (new DOMParser()).parseFromString(str, "text/xml");
}
//然后開始...和其它兩個(gè)reader一樣的用法,只是這兒換了一種寫法,recordtype也可以是一個(gè)record對象
var record = Ext.data.Record.create([
{name: 'name', mapping: 'name'}, // "mapping" property not needed if it's the same as "name"
{name: 'occupation'} // This field will use "occupation" as the mapping.
])
var reader = new Ext.data.XmlReader({
totalRecords: "results",
record: "row", //row是節(jié)點(diǎn)選擇器
id: "id"
}, record);
var data=reader.readRecords(xmlDocument);
ExtJS教程-
Hibernate教程-
Struts2 教程-
Lucene教程