EXT核心API详解(九)-Ext.data-DataProxy/HttpProxy/MemoryProxy/ScriptTagProxy javascript

本文介绍了Ext数据代理类的基础概念及其实现方式,包括HttpProxy、MemoryProxy和ScriptTagProxy等几种类型的数据代理。这些代理主要用于生成Ext.data.Record对象,通过不同的方式从服务器获取数据。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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

放弃
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值