[04]EXTJS4.0的数据代理-Proxy

 数据代理proxy是进行数据读写的主要途径,通过代理操作数据进行CRUD

每一步操作都会得到唯一的Ext.data.Operation实例,它包含了所有的请求参数
1.数据代理proxy目录结构
Ext.data.proxy.Proxy 代理类的根类(它分为客户端(Client)代理和服务器代理(Server))
     Ext.data.proxy.Client 客户端代理
          Ext.data.proxy.Memory  普通的内存代理
          Ext.data.proxy.WebStorage 浏览器客户端存储代理
               Ext.data.proxy.SessionStorage  浏览器级别代理(session)
               Ext.data.proxy.LocalStorage 本地化级别代理(等同于cookies)
     Ext.data.proxy.Server 服务器端代理
         Ext.data.proxy.Ajax 异步加载的方式
              Ext.data.proxy.Rest  一种特殊的Ajax
         Ext.data.proxy.JsonP  跨域交互的代理   跨域是有严重的安全隐患的,extjs的跨域也是需要服务器端做相应的配合
         Ext.data.proxy.Direct 命令
         3+方式的代理
资料
REST指Representational State Transfer(有时写作"ReST"),表示状态转移,其要求无状态、客户端-服务器、具有缓存机制的通信协议——实际上是使用HTTP协议。
RESTful应用使用HTTP请求来POST数据(创建和/或更新)、读取数据(例如,进行查询)、删除数据。
这样,REST使用HTTP来进行CRUD(Create/Read/Update/Delete)操作
lesson4.html
  
  
  
  
  1. <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN"> 
  2. <html> 
  3. <head> 
  4. <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> 
  5. <title>proxy</title> 
  6. <link rel="stylesheet" type="text/css" href="../extjs-4.1.0/resources/css/ext-all.css"/> 
  7. <script type="text/javascript" src="../extjs-4.1.0/bootstrap.js"></script> 
  8. <script type="text/javascript" src="jsonp.js"></script> 
  9. </head> 
  10. <body> 
  11. </body> 
  12. </html> 
---------------------------------------------------------------------------------------
memory.js
  
  
  
  
  1. (function(){ 
  2.    Ext.onReady(function(){    
  3.        Ext.define("user",{ 
  4.         extend:'Ext.data.Model', 
  5.         fields:[ 
  6.             {name:'name',type:'string'}, 
  7.             {name:'age',type:'int'} 
  8.         ] 
  9.       }); 
  10.      //不用create方法,我们直接用proxy来创建对象数据 
  11.      var userData = [ 
  12.        {name:'uspcat.com',age:1}, 
  13.        {name:'yunfengcheng',age:26} 
  14.      ]; 
  15.      var memoryProxy = Ext.create("Ext.data.proxy.Memory",{ 
  16.         data:userData, 
  17.         model:'user' 
  18.      }); 
  19.       
  20.     userData.push({name:'new upcast.com',age:1}); 
  21.       
  22.      //update 
  23.      /*在这个版本上根本就不能用 
  24.       *下面的代码虽然没有错误,但是没有实际用处 
  25.      */ 
  26.      var operation = new Ext.data.Operation({action:'update'}); 
  27.      operation.resultSet={ records:[Ext.create('user',{name:'name',age:2})]}; 
  28.      memoryProxy.update(operation,function(result){},this); 
  29.       
  30.      //就可以做CRUD了 
  31.      memoryProxy.read(new Ext.data.Operation(),function(result){ 
  32.             console.log(result); 
  33.             //得到user这个模型的两个对象 
  34.             var datas = result.resultSet.records; 
  35.             Ext.Array.each(datas,function(model){ 
  36.                 console.log(model.get('name')); 
  37.             }); 
  38.      }); 
  39.    });   
  40. })(); 
--------------------------------------------------------------------------------
localstorage相当于cookies,关闭浏览器之后还是可以读到的
localstorage.js
  
  
  
  
  1. (function(){ 
  2.     Ext.onReady(function(){ 
  3.         Ext.regModel("user",{ 
  4.             fields:[ 
  5.                 {name:'name',type:'string'}  
  6.             ], 
  7.             proxy:{ 
  8.                 type:'localstorage'
  9.                 id:'twitter-Searches' 
  10.             }    
  11.         }); 
  12.         //我们用store来初始化数据 
  13.         var store = new Ext.data.Store({ 
  14.             model:user   
  15.         }); 
  16.         store.add({name:'uspcat.com'}); 
  17.         store.sync(); 
  18.         store.load(); 
  19.         var msg = []; 
  20.         store.each(function(rec){ 
  21.             msg.push(rec.get('name')); 
  22.         }); 
  23.         console.log(msg.join("\n")); 
  24.     });  
  25. })(); 
------------------------------------------------------------------------------------
sessionstorage相当于session,关闭浏览器之后一切都要从头开始
sessionstorage.js
  
  
  
  
  1. (function(){ 
  2.     Ext.onReady(function(){ 
  3.         Ext.regModel("user",{ 
  4.             fields:[ 
  5.                 {name:'name',type:'string'}  
  6.             ], 
  7.             proxy:{ 
  8.                 type:'sessionstorage'
  9.                 id:'twitter-Searches' 
  10.             }    
  11.         }); 
  12.         //我们用store来初始化数据 
  13.         var store = new Ext.data.Store({ 
  14.             model:user   
  15.         }); 
  16.         store.add({name:'new uspcat.com'}); 
  17.         store.sync(); 
  18.         store.load(); 
  19.         var msg = []; 
  20.         store.each(function(rec){ 
  21.             msg.push(rec.get('name')); 
  22.         }); 
  23.         console.log(msg.join("\n")); 
  24.     });  
  25. })(); 
-------------------------------------------------------------------------------------
ajax.js
  
  
  
  
  1. (function(){ 
  2.     Ext.onReady(function(){ 
  3.             Ext.define('User', { 
  4.               extend: 'Ext.data.Model'
  5.               fields: [ 
  6.                   {name: 'name',  type: 'string'
  7.               ] 
  8.             });  
  9.             var ajaxProxy = new Ext.data.proxy.Ajax({ 
  10.                  url:'person.jsp'
  11.                  model:User, 
  12.                  reader:'json'
  13.                  limitParam:'indexLimit' 
  14.             }); 
  15.       ajaxProxy.doRequest(new Ext.data.Operation({ 
  16.         action:'read'
  17.         limit:10, 
  18.         start:1, 
  19.         sorters:[ 
  20.           new Ext.util.Sorter({ 
  21.               property:'name'
  22.                 direction:'ASC'  
  23.           }) 
  24.  
  25.         ]    
  26.       }),function(o){ 
  27.          console.log(o); 
  28.          var text = o.response.responseText; 
  29.          console.log(Ext.JSON.decode(text)['name']); 
  30.       }); 
  31.     });  
  32. })(); 
person.js
 
  
  
  
  
  1. <%@page language="java" contentType="text/html" pageEncoding="UTF-8"%> 
  2. <% 
  3.    System.out.println(request.getParameter("id")); 
  4.    response.getWriter().write("{name:'upcat.com'}"); 
  5. %> 
---------------------------------------------------------------------------------
 
jsonp.js
  
  
  
  
  1. (function(){ 
  2.             Ext.define('person', { 
  3.               extend: 'Ext.data.Model'
  4.               fields: [ 
  5.                   {name: 'name',  type: 'string'
  6.               ], 
  7.               proxy:{ 
  8.                 type:'jsonp'
  9.                 url:'http://www.uspcat.com/extjs/person.php'     
  10.               } 
  11.             });  
  12.             var person = Ext.ModelManager.getModel('person'); 
  13.             person.load(1,{ 
  14.                 scope:this
  15.                 success:function(model){ 
  16.                     console.log(model.get('name')); 
  17.                 } 
  18.             }); 
  19.  
  20. })(); 
控制台的输出结果是:
uspcat
===============================================
跨域访问机制:
在服务器上,同一个域中的文件,数据或者swf可以任意访问。若要跨域访问需被授权。注意不同域名即使映射到相同IP地址也会被看成两个域。IP地址名和通过解析的地址也被看作两个域。
 

 

你可能感兴趣的:(extjs4,教程,技术狂人论坛)