Extjs 数据代理
Ext.data.proxy.Proxy 代理类的根类
客户端代理:
1.LocalStorageProxy:将数据存储在localStorage中,此种方式可以持久的将数据存储在客户端
要使用代理,我们首先要有一个数据模型类,我们定义一个简单的Person类:
Ext.define('Person', {extend: 'Ext.data.Model', fields: ['name', 'age']});
有了Model,我们还需要一个Store。我们可以把 Store 理解为数据仓库, 它对应数据库中的表,而Store 包含的 Record 则是数据表中的每一行记 录。我们同样简单的创建一个Store对象:
var personStore = Ext.create("Ext.data.Store", { model: 'Person'});
接下来就到我们代理出场的时候了。我们需要创建一个LocalStorageProxy:
var personProxy = new Ext.data.proxy.LocalStorage({ id: 'Person_LocalStorage', model: 'Person'});
将代理和Store 联系在一起
personStore.setProxy(personProxy);
际应用中,可以在Model 或 Store 中直接使用proxy 选项,
我们在后面的示例中将会看到具体的用法。
personStore.add({ name: 'www.qeefee.com', age: 1 }); personStore.add({ name: 'qf', age: 26 }); personStore.add({ name: 'qifei', age: 26 }); personStore.sync();
要查看保存的数据,我们需要先将数据从LocalStorage中加载到Store 中,
然后对Store 进行遍历:
personStore.load();
var msg = [];
personStore.each(function (person) { msg.push(person.get('name') + ' ' + person.get('age'));
});
Ext.MessageBox.alert('提示', msg.join('<br />'));
使用load方法会将所有的数据都加载到Store中,如果我们需要进
行查询指定的数据,就要用到filter方法了
personStore.filter("name", /\.com$/);
使用多个过滤条件:
personStore.filter([
{ property: "name", value: /\.com$/ },
{ filterFn: function (item) { return item.get("age") > 10; } } ]);
使用过滤条件代替过滤方法
personStore.filter(function (item) {
return item.get("age") > 10 && item.get('name').length > 3;});
更新操作:
//得到第一个person对象
var person = personStore.first();
//修改名字字段
person.set('name', 'qeefee.com');
//保存到本地
personStore.sync();
删除操作:
//得到第一个person对象
var person = personStore.first();
//移除
personStore.remove(person);
//保存
personStore.sync();
2.SessionStorageProxy:将数据存储在sessionStorage中,
此种方式只在当前会话中生效,当关闭浏览器以后,数据也会随之丢失。
用法与LocalStorageProxy 的用法基本一致,我们这次在Model中添加 proxy 的配置项
//定义数据模型
Ext.define('Person', {extend: 'Ext.data.Model', fields: ['name', 'age'], proxy: {type: 'sessionstorage',
id: 'myProxyKey' }});
在Model中加入代理配置以后,我们就不需要单独的定义代理对象了,
可以直接使用Store来对其进行操作
//定义Store
var personStore = Ext.create("Ext.data.Store", { model: 'Person'});
//添加数据
personStore.add({name:'www.baidu.com',age:1}); personStore.add({name:'qf',age:26 });
personStore.add({name:'qifei',age: 26 });
personStore.sync();
//读取数据
personStore.load();
Var msg=[];
personStore.each(function(person){ msg.push(person.get('name') + ' ' + person.get('age'));
});
Ext.MessageBox.alert('提示', msg.join('<br />'));
3.MemoryProxy:将数据存储在内存中,此种方式只在当前页面有效,
且如果刷新页面,数据将丢失。
//定义数据模型
Ext.define('Person', { extend: 'Ext.data.Model',
fields: ['name', 'age']});
var data = {Users: [{ name: 'www.baidu.com', age: 1 },
{ name: 'qeefee', age: 1 }]}
//定义Store
var personStore = Ext.create("Ext.data.Store", {
model: 'Person',
data: data.Users, proxy: {type: 'memory'}});
在代码中高亮显示的部分,就是为store设置的缓存。当personStore 定义的时候,它就会自动的将数据加载到Store中,所以在我们访问数据的时候不需要再调用load方法了:
//读取数据
Var msg=[];
personStore.each(function(person) {
msg.push(person.get('name')+'
'+person.get('age'));});
Ext.MessageBox.alert('提示', msg.join('<br />'));
和上两个的操作基本一致,我们可以通过下面的代码添加一行新数据:
personStore.add({ name: 'qifei', age: 26 });
personStore.sync();
服务端代理模式有:
Ajax : 在当前域中发送请求。
JsonP: 跨域的请求。
Rest : 与服务器进行RESTful(GET/PUT/POST/DELETE)交互
Direct: 使用 Ext.direct.Manager 发送请求。
常用的代理模式Ajax
示例:
Ext.onReady(function(){
Ext.define('Person',{extend: 'Ext.data.Model',
fields: ['name', 'age']
});
var store= Ext.create('Ext.data.Store',
{model:'Person',
proxy: {
type: 'ajax',
url: rootUrl +'sample/getjson',
reader:{ type: 'json', root: 'users'}}
});
store.load();
var msg = [];
store.each(function(person){
msg.push(person.get('name')+''+person.get('age'));
});
Ext.MessageBox.alert('提示', msg.join('<br />')); });
在这段代码中,首先定义了Model类Person,然后创建了Person类的数据仓库 store,store 使用了ajax代理,通过url向服务器请求数据,ajax代理的reader 配置项是告诉程序以何种方式读取请求到的数据。
服务器返回的JSON 字符串如下:
{users:[{name:'www.baidu.com', age:1}, {name:'Tom', age:26}]}
如果你打开网络跟踪,会发现程序已经将成功得到了这段JSON字符串。那是为什么仍然是空呢?
原因是当我们调用load()方法的时候,我们告诉store去请求数据吧,然后store就使用ajax的方式请求url,注意,ajax 是异步的,所以当我们调用load()方法以后,马上执行输出的时候,store仍然是空的,可能它还在等待服务器响应数据。
所以,在我们使用ajax方式加载数据的时候,就需要为load() 方法添加一个callback 方法,当数据加载完成以后,再callback方法中进行数据输出,修改load方法的调用:
store.load({
callback:function(records,operation,success){
if(success){varmsg=[];store.each(
function(person){
msg.push(person.get('name') + ' ' + person.get('age'));
});
Ext.MessageBox.alert('提示', msg.join('<br />'));}}
});
在使用ajax进行请求的时候,ajax代理会调用自身的read方法,该方法的第一个参数是Ext.data.Operation 类型,它用来配置我们如何进行请求。我们在load 方法中可以通过配置项传递一些参数,load在调用read方法时将这些参数传递过去,read则会根据这些参数生成Ext.data.Operation 的一个实例。所以,我们可以这样来传递参数
store.load({
page: 2,
limit:10,params:{name:'QF'},
callback:function(records,operation,success){
if(success){varmsg=[];store.each(function(person) {msg.push(person.get('name') + ' ' + person.get('age'));
});
Ext.MessageBox.alert('提示', msg.join('<br />')); }}});
/SampleExtJS/sample/getjson?_dc=1374141754304&name=QF&pag e=2&start=25&limit=10
通过传递这些参数,我们可以完成分页、查询等操作。
JsonP
在ExtJS 中我们可以轻松的使用JsonP代理进行跨域的数据请求:
//创建Store
var store = Ext.create('Ext.data.Store', {model: 'Person', proxy: {
type: 'jsonp',
url: 'http://www.abc.com/sampleextjs/sample/getjsonp',
reader: {type: 'json', root:'users'}}
});
务器返回的字符串为:
Ext.data.JsonP.callback1({
users: [{ name: 'www.baidu.com', age: 1 },
{ name: 'QF', age: 26 }]
})
Direct 代码使用Ext.Direct 向服务器发动数据。
Ext.Direct 技术的好处是,允许你像调用Javascript 方法一样调用服务器端代码
Ext.define('User', {
extend: 'Ext.data.Model',
fields: ['firstName', 'lastName'],
proxy: { type: 'direct', directFn: MyApp.getUsers, paramOrder: 'id' }
});
User.load(1);
参考:http://www.qeefee.com/extjs-course-6-server-proxy
Extjs 数据代理的更多相关文章
- ExtJs4学习(八)数据代理Proxy
ExtJs数据代理我们介绍常用的四种,但会着重介绍ajax代理,因为日常开发中,这个最为常用 Ext.data.proxy.Ajax AjaxProxy(Ajax数据代理类)是你的应用程序中使用最广泛 ...
- Javascript - ExtJs - 数据
数据(ExtJs Data) Ext.data命名空间 有关数据存储.读取的类都定义在Ext.data命名空间中.Ext的gridPanel.combobox的数据源都是来自Ext.data提供的类. ...
- MVVM数据代理
MVVM数据代理 function MVVM(options) { this.$options = options || {}; var data = this._data = this.$optio ...
- vue的数据代理
1. vue数据代理: data对象的所有属性的操作(读/写)由vm对象来代理操作2. 好处: 通过vm对象就可以方便的操作data中的数据3. 实现: 1). 通过Object.defineProp ...
- 对数据劫持 OR 数据代理 的研究------------引用
数据劫持,也叫数据代理. 所谓数据劫持,指的是在访问或者修改对象的某个属性时,通过一段代码拦截这个行为,进行额外的操作或者修改返回结果.比较典型的是 Object.defineProperty() 和 ...
- 数据代理Object.defineProperty()
数据代理: 通过一个对象代理对另一个对象中属性的操作(读/写) 数据代理 Object.defineProperty() Object.defineProperty() 方法会直接在一个对象上定义一个 ...
- vue中的数据代理原理
const vm = new Vue({ data:{ name:'boos' } }) // 注意 :使用构造函数构建vue实例时,传入的是一个option对象,它包含了data,computed等 ...
- es6中的Proxy和vue中的数据代理的异同
1:概述 1-1:Proxy 用于修改某些操作的默认行为,Proxy可以说在对对象进行各种访问或者操作的时候在外层进行一层拦截,在操作之前都需要经过这种拦截.proxy返回的是一个新对象,可以通过操作 ...
- Vue学习之--------el与data的两种写法、MVVM模型、数据代理(2022/7/5)
文章目录 1.el与data的两种写法 1.1.基础知识 1.2.代码实例 1.3.页面效果 2.MVVM模型 2.1. 基础知识 2.2 .代码实例 2.3.页面效果 3.数据代理 3.1. 基础知 ...
随机推荐
- 【转】进程间通信方式总结(windows 和linux)
平时看的书很多,了解的也很多,但不喜欢总结,这不昨天面试的时候被问到了进程间通信的方式,因为没有认真总结过,所以昨天答得不是特别好.现在将linux和windows的进程间通信方式好好总结一下. ...
- Android与JNI(三) ---- c++调用java(转载)
源码下载:JniDemo JNI就是Java Native Interface, 即可以实现Java调用本地库, 也可以实现C/C++调用Java代码, 从而实现了两种语言的互通, 可以让我们更加灵活 ...
- VirtualBox 安装增强工具
菜单的: Device>insert guest addtion. 定位: cd /media/cdrom 安装: sudo sh ./VBoxLinuxAdditions-x86.run 然 ...
- Python3基础 用while 循环求解 一个整数的阶乘
镇场诗: 诚听如来语,顿舍世间名与利.愿做地藏徒,广演是经阎浮提. 愿尽吾所学,成就一良心博客.愿诸后来人,重现智慧清净体.-------------------------------------- ...
- JAVA中用于处理字符串的“三兄弟”
JAVA中用于处理字符串常用的有三个类:java.lang.String.java.lang.StringBuffer.java.lang.StringBuilder,这三者的共同之处都是final类 ...
- poi jar包介绍
来自官网: Component Application type Maven artifactId Notes POIFS OLE2 Filesystem poi Required to work w ...
- jquery换肤
<script src="script/jquery-2.1.0.js"></script> <link href="style/ ...
- 解剖 Elasticsearch 集群 - 之三
解剖 Elasticsearch 集群 - 之三 本篇文章是一系列涵盖 Elasticsearch 底层架构和原型示例的其中一篇.在本篇文章中,我们会讨论 Elasticsearch 如何提供准实时搜 ...
- HDU2063(二分图最大匹配)
过山车 Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submiss ...
- linux 中c/c++实现终端命令行命令
在终端中可以从用下面命令获得帮助: man system 在c/c++代码中实现和在终端中输入的命令行一样的效果,以命令(audacious -p &)为例,该代码实现用audacious在后 ...