我们先来看看Extjs非常绚丽的Grid,其功能包括显示数据列表,修改、删除,分页,排序等功能。   Grid组件用来显示Store中的数据。Store可以看做是Model实例的集合。Grid仅关心如何显示数据,而Store关心如何通过Proxy来读取和保存数据。

下面进入正题Proxy   考虑到数据可能保存在服务器端,也可能保存在客户端本地,所以Proxy有两个子类Server和Client。  Server用来和服务器端进行数据读取和保存,相应的Client用来在客户端保存和读取数据。  Server主要是利用Ajax技术进行和服务器端交互。而Client则主要借助客户端变量以及html5的localStorage 和 session storage 来存储数据。

下面细致讲解类的封装: Proxy定义了对外统一的访问接口CRUD(Create、Read、Update、Delete)以及持有Model对象、Reader和Writer对象。 其中Model 用来标识出装载和保存数据的类型。 Reader:用来解析服务器端返回的数据。 Writer:格式化向服务器端发送的数据。 此外Proxy还提供了批量发送请求的方法。
Client作为Proxy的子类,定义了清除客户端数据的接口,要求子类实现。 Client的子类有三个 Ext.data.proxy.Memory:简单的使用变量来存储数据,所以页面刷新后数据会丢失。 Ext.data.proxy.LocalStorage :使用html5的localStorage API 来存储数据 Ext.data.proxy.SessionStorage :使用HTML5 session storage 来存储数据 html5中的Web Storage包括了两种存储方式:sessionStorage和localStorage。
sessionStorage用于本地存储一个会话(session)中的数据,这些数据只有在同一个会话中的页面才能访问并且当会话结束后数据也随之销毁。因此sessionStorage不是一种持久化的本地存储,仅仅是会话级别的存储。
而localStorage用于持久化的本地存储,除非主动删除数据,否则数据是永远不会过期的。
web storage和cookie的区别 Web Storage的概念和cookie相似,区别是它是为了更大容量存储设计的。Cookie的大小是受限的,并且每次你请求一个新的页面的时候Cookie都会被发送过去,这样无形中浪费了带宽,另外cookie还需要指定作用域,不可以跨域调用。
除此之外,Web Storage拥有setItem,getItem,removeItem,clear等方法,不像cookie需要前端开发者自己封装setCookie,getCookie。
但是Cookie也是不可以或缺的:Cookie的作用是与服务器进行交互,作为HTTP规范的一部分而存在 ,而Web Storage仅仅是为了在本地“存储”数据而生。

Server 作为Proxy的子类,被设计用来向服务器端发送数据。这个类主要定义了分页、分组排序过滤等默认参数,通过代理模式为CRUD这四个方法提供统一的处理方法doRequest,封装请求数据buildRequest,以及解析服务器返回数据processResponse。

这里我们重点关注Server的buildRequest和processResponse

Server的buildRequest方法,根据请求参数Ext.data.Operation提供的信息构造出Ext.data.Request 对象,其中Request 形如:

{

action: undefined,      params: undefined,       method: 'GET',      url: undefined,

}

Server的processResponse方法,主要是从response对象中解析出所有的Ext.data.Model实例,然后调用Operation的commitRecords方法将服务器端返回的Model更新到客户端缓存的数据上,即更新Store中缓存的数据。

Server的子类有三个 Ext.data.proxy.Ajax         使用Json方式向服务器端发送数据和接收数据 Ext.data.proxy.Direct      通过Ajax使得客户端可以直接调用服务器端的方法。还提供了轮询方式向服务器端发送请求。 Ext.data.proxy.JsonP     可以跨域向服务器端发送请求
上面这三个类最终都是通过调用Connection类的request 方法向服务器端发送Ajax请求。

这里我们重点关注Connection的request 方法
Connection的request 方法主要用来创建XMLHttpRequest对象发送请求信息到服务器端,接收服务器返回数据并执行回调函数。

首先通过getXhrInstance方法屏蔽掉浏览器之间创建XMLHttpRequest的差异。

当服务器返回数据后调用onComplete方法,将.responseText 和responseXML以及服务器返回的状态信息status等包装到response对象中,作为回调函数的参数。如果状态成功就调用success方法,失败就调用failure方法,最后无论成功还是失败都调用callback方法。

extjs Proxy的更多相关文章

  1. Extjs PROXY查询params无法传参,改用extraParams

  2. [EXT JS]"hasMany" association on ExtJS 4.1.1a

    ExtJS uses "hasMany" association to support nested json. However the sencha docs lacks wel ...

  3. ExtJS 4.2 教程-06:服务器代理(proxy)

    转载自起飞网,原文地址:http://www.qeefee.com/extjs-course-6-server-proxy ExtJS 4.2 教程-01:Hello ExtJS ExtJS 4.2 ...

  4. EXTJS之DATA PROXY READER

    这是不依赖于STORE的读取.我测试了很久,原来在新版本的EXTJS里.modelmanager.getmodel之类的不用了. 更改为静态的LOAD办法. <!DOCTYPE html> ...

  5. EXTJS动态改变store的proxy的params

    动态改变store的条件参数.var store = win.down('grid[name=sourceGrid]').getStore(); Ext.apply(store.proxy.extra ...

  6. ExtJS笔记 Proxy

    Proxies are used by Stores to handle the loading and saving of Model data. Usually developers will n ...

  7. ExtJS 4.2 教程-05:客户端代理(proxy)

    转载自起飞网,原文地址:http://www.qeefee.com/extjs-course-5-client-proxy ExtJS 4.2 教程-01:Hello ExtJS ExtJS 4.2 ...

  8. ExtJS 4.2 业务开发(二)数据展示和查询

    本篇开始模拟一个船舶管理系统,提供查询.添加.修改船舶的功能,这里介绍其中的数据展示和查询功能. 目录 1. 数据展示 2. 数据查询 3. 在线演示 1. 数据展示 在这里我们将模拟一个船舶管理系统 ...

  9. ExtJS 4.2 业务开发(三)数据添加和修改

    接上面的船舶管理业务,这里介绍添加和修改操作. 目录 1. 添加操作 2. 修改操作 3. 在线演示 1. 添加操作 1.1 创建AddShipWindow.js 在业务中的view目录下创建一个Ad ...

随机推荐

  1. 实战-Mysql5.6.36脚本编译安装及初始化

    概述 本文为centos7.3自动化编译安装mysql5.3.6的脚本及后续初始化操作,话不多少,直接上脚本. 安装脚本install.py如下: #coding=utf-8 #!/usr/bin/p ...

  2. 基于Spring Aop实现类似shiro的简单权限校验功能

    在我们的web开发过程中,经常需要用到功能权限校验,验证用户是否有某个角色或者权限,目前有很多框架,如Shiro Shiro有基于自定义登录界面的版本,也有基于CAS登录的版本,目前我们的系统是基于C ...

  3. QScintilla 编译

    直接上英文了,不翻译了.看不懂的可以留言哈. ———————————————————————————————————————— Installation As supplied QScintilla ...

  4. 【回文】leetcode - Shortest Palindrome

    题目: Shortest Palindrome Given a string S, you are allowed to convert it to a palindrome by adding ch ...

  5. struts2 maven整合tiles3

    最新项目发现使用tiles能够很好的将多个页面组合起来,以下就是配置信息,使用tiles3 1.首先配置maven pom.xml加入例如以下: <dependency> <grou ...

  6. [Android] AutoCompleteTextView:自己主动完毕输入内容的控件(自己主动补全)

    AutoCompleteTextView是EditText的直接子类,与普通EditText的最大不同就是.在用户输入的过程中,能够列出可供选择的输入项.方便使用者. AutoCompleteText ...

  7. http get(swift and oc)

    SynchonousRequest: let urlPath: String = "http://www.weather.com.cn/data/sk/101010100.html" ...

  8. Java加载资源文件的两种方法

    处理配置文件对于Java程序员来说再常见不过了,不管是Servlet,Spring,抑或是Structs,都需要与配置文件打交道.Java将配置文件当作一种资源(resource)来处理,并且提供了两 ...

  9. Elasticsearch布尔查询——bool

    布尔查询允许我们利用布尔逻辑将较小的查询组合成较大的查询. 1.查询返回包含"mill"和"lane"的所有的账户 curl -XPOST 'localhost ...

  10. PXE搭建

    前提最好是防火墙规则-F,关闭,selinux 是disable 这个在以后更新linux系统的时候还可以在这个基础上再次增加可以一体化安装的系统. 1.用yum来安装所需要的软件包,先来搭建yum光 ...