zoukankan      html  css  js  c++  java
  • Ext.dataDataProxy/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
    参见HttpProxy

     

  • 相关阅读:
    platform cannot apply stanford theme
    汉化、用户创建
    修改字段
    语言包格式错误引起组件崩溃
    配置LMS/Studio SMTP
    Javascript如何实现AOP
    【转】组件化的Web王国
    【转】前端组件化框架之路
    【转】ES6 手册
    【转】超实用的JavaScript技巧及最佳实践
  • 原文地址:https://www.cnblogs.com/meetrice/p/1206052.html
Copyright © 2011-2022 走看看