Ext.data-DataProxy/HttpProxy/MemoryProxy/ScriptTagProxy

Ext.data-DataProxy/HttpProxy/MemoryProxy/ScriptTagProxy

Ext.data.DataProxy
   数据代理类是一个纯虚类,主要用于生成Ext.data.Record对象,没有公开的属性和方法,只是归定子类需要处理三个事件
beforeload : ( Object This, Object params )
load : ( Object This, Object o, Object arg )
loadexception : ( Object This, Object o, Object arg, Object e )
事实上参数也是子类自定义的

Ext.data.HttpProxy
   api文档中说httpProxy是从object继承来的,事实上source中它和下面的Ext.data.MemoryProxy/Ext.data.ScriptTagProxy都继承于DataProxy

HttpProxy用于远程代理,而且服务端返回信息时必须指定Content-Type属性为"text/xml".
HttpProxy( Object conn )
构造一个HttpProxy对象,参数可以是一个类似于{url: 'foo.php'}这样的json对象,也可以是一个Ext.data.Connection对象,如果参数没有指定,将使用Ext.Ajax对象将被用于发起请求

getConnection() : Connection
得到当前连接对象

load( Object params, Ext.data.DataReader reader, Function callback, Object scope, Object arg ) : void
从配置的connection对象得到record数据块,并激发callback
  params:        发起http请求时所要传递到服务端的参数
  DataReader:    见DataReader
  callback:    回叫方法,第一个参数为接收到的信息,第二个参数为arg,第三个是成功标志
  scope:        范围
  arg:        这儿的参数将会传递给回叫函数callback

使用示例: var proxy=new Ext.data.HttpProxy({url:'datasource.xml'});

    //关于reader将会在Ext.data.DataReader中讲解

    var reader = new Ext.data.XmlReader({

      totalRecords: "results",

      record: "row",       

      id: "id"               

    }, [

      {name: 'name', mapping: 'name'},

      {name: 'occupation'}         

    ]);

 

    //定义回叫方法

    var metadata;

    function callback(data,arg,success){

        if(success){

            metadata=data;

        }

    }

    //从connection配置的url中利用reader将返回的xml文件转为元数据,并传递给callback

    proxy.load( null,reader,callback,this);
复制代码
Ext.data.MemoryProxy
MemoryProxy( Object data )
构造
load( Object params, Ext.data.DataReader reader, Function callback, Object scope, Object arg ) : void
取数据,和HttpProxy类似,只是params参数没有被使用

使用示例 var proxy=new Ext.data.MemoryProxy([ [1, 'Bill', 'Gardener'], [2, 'Ben', 'Horticulturalist'] ]);

var reader = new Ext.data.ArrayReader(

{id: 0},

[

{name: 'name', mapping: 1},       

{name: 'occupation', mapping: 2} 

]);



var metadata;

function callback(data,arg,success){

    metadata=data;

}

proxy.load( null,reader,callback,this);
复制代码

Ext.data.ScriptTagProxy
   这个类和HttpProxy类似,也是用于请求远程数据,但能用于跨主域调用,如果请求时使用了callback参数
则服务端应指定Content-Type属性为"text/javascript"
并返回callback(jsonobject)
反之则应置Content-Type属性为"application/x-json"
并直接返回json对象

ScriptTagProxy( Object config )
构造,其中
config定义为{
  callbackParam : String,//回叫参数
  nocache : Boolean,//是否缓存
  timeout : Number, //超时
  url : String      //请求数据的url
}

abort() : void
放弃

load( Object params, Ext.data.DataReader reader, Function callback, Object scope, Object arg ) : void

来源:9iext.cn
原文地址:http://www.9iext.cn/thread-26-1-1.html

你可能感兴趣的:(JavaScript,Ajax,json,xml,ext)