使用Store ajax的方式来获取数据

    <div id="grid1">    </div>
<script>
Ext.onReady(function() {
var store = new Ext.data.JsonStore({
storeId: 'myStore',
// autoLoad: true,//加上这个配置 就无需手动的写store.load()
proxy: {
type: 'ajax',
url: 'getImage.php',
reader: {
type: 'json',
root: 'images', //getData的函数最先触发
//这里配置过getData就相当于把数据取走了
//后面on事件 函数就不能通过records取到数据了 还是可以通过store.getProxy().getReader().rawData去到数据
// afterRequest 则根本取不到数据
// getData: function(data){
// console.log('getData in reader');
// console.log(data);
// }
}
// ,
// afterRequest: function(req, res) {
// console.log("After Request!", req.operation.response);
// }
}, //alternatively, a Ext.data.Model name can be given (see Ext.data.Store for an example)
fields: ['name', 'url', {
name: 'size',
type: 'float'
}, {
name: 'lastmod',
type: 'date'
}]
});
store.on({
'load': function(store, records, success, opts) {
console.log('on1');
console.log(success);
//records 是 []
console.log(records);
//PS rawData是一个{}
console.log(store.getProxy().getReader().rawData);
}
}, this, {single:true});
store.on('load', function(store, records, success, eOpts ){
console.log('on2');
console.log(success);
console.log(records);
console.log(store.getProxy().getReader().rawData);
});
//这个就是手动load 只是在store.load()的基础上传入了一个config
store.load({
callback: function(records, opts, success) {
console.log('load');
console.log(success);
console.log(records);
}
});
console.log(store);
var grid = new Ext.grid.Panel({
renderTo: 'grid1',
store: store,
columns: [{
header:'NAME',
dataIndex: 'name'
}, {
header:'URL',
dataIndex: 'url'
}, {
header: 'SIZE',
dataIndex:'size'
}, {
header: 'LASTMOD',
dataIndex:'lastmod'
}]
})
}); </script>

响应

<?php
echo '{"images":[{"name":"Image one","url":"/GetImage.php?id=1","size":46.5,"lastmod":"2007-11-28T16:00:00.000Z"},{"name":"Image Two","url":"/GetImage.php?id=2","size":43.2,"lastmod":"2007-11-29T16:00:00.000Z"}]}';
?>

PS 动态添加列

        var fields = ['name', 'url', {
name: 'size',
type: 'float'
}, {
name: 'lastmod',
type: 'date'
}];
var columns = [{
header: 'NAME',
dataIndex: 'name'
}, {
header: 'URL',
dataIndex: 'url'
}, {
header: 'SIZE',
dataIndex: 'size'
}, {
header: 'LASTMOD',
dataIndex: 'lastmod'
}];
var store = new Ext.data.JsonStore({
storeId: 'myStore',
// autoLoad: true,//加上这个配置 就无需手动的写store.load()
proxy: {
type: 'ajax',
url: 'getImage.php',
reader: {
type: 'json',
root: 'images',
},
afterRequest: function(req, res) {
console.log("After Request!", req.operation.response);
}
},
fields: fields
});
var grid = new Ext.grid.Panel({
renderTo: 'grid1',
store: store,
columns: columns
})
var column = Ext.create('Ext.grid.column.Column', {
text: 'New Column',
dataIndex:'newColumn'
});
var field = new Ext.data.Field({
name:'newColumn'
});
fields.push(field);
grid.getStore().model.setFields(fields);
grid.getStore().reload();
grid.headerCt.insert(grid.columns.length, column);
grid.getView().refresh();

不过对于Ext4.0.7版本 则没有 setFields 方法

                    newCols.forEach(function(item){
fields.push(item.dataIndex);
_columns.push({
header: item.header,
dataIndex: item.dataIndex
});
});
var storeNew = new Ext.data.Store({
fields: fields,
data: result.data,
reader: {
root: 'data',
totalProperty: 'total'
}
});
grid.reconfigure(storeNew, _columns);
grid.setLoading(false);

使用JsonP的Proxy

    Ext.onReady(function() {

        var columns = [{
header: '编号',
dataIndex: 'id'
}, {
header: '名称',
dataIndex: 'name'
}, {
header: '描述',
dataIndex: 'descn'
}]; //JsonP有两种实现方式
var store = new Ext.data.Store({
proxy: new Ext.data.ScriptTagProxy({
url: 'http://www.mossle.com/data.json',
// reader: new Ext.data.JsonReader({
// totalProperty: "totalProperty",
// root: "root",
// id: "id"
// }),
// 这两种reader的写法都可以
reader:{
totalProperty: "totalProperty",
root: "root",
id: "id"
}
}),
fields: [{
name: 'id'
}, {
name: 'name'
}, {
name: 'descn'
}]
}); var store = new Ext.data.Store({
proxy:{
type:'jsonp',
url: 'http://www.mossle.com/data.json',
reader: {
totalProperty: "totalProperty",
root: "root",
id: "id"
},
callbackKey: 'callback' //也可以不写 因为默认这个key就是 callback
},
fields: [{
name: 'id'
}, {
name: 'name'
}, {
name: 'descn'
}]
}) var grid = new Ext.grid.GridPanel({
renderTo: 'grid',
width: 350,
height: 150,
loadMask: true,
store: store,
columns: columns
});
store.load(); });

响应

Ext.data.JsonP.callback1({"id":0,"totalProperty":5,"successProperty":true,"root":[{"id":"1","name":"name1","descn":"descn1"},{"id":"2","name":"name1","descn":"descn1"},{"id":"3","name":"name1","descn":"descn1"},{"id":"4","name":"name1","descn":"descn1"},{"id":"5","name":"name1","descn":"descn1"}]})

Ext Store Proxy Ajax的更多相关文章

  1. Extjs6设置Store、Ajax、form的请求方式(GET、POST)

    Extjs6 设置Store.Ajax.form的请求方式(GET.POST) Ajax请求和Form的submit方法设置请求方式和原来一样,使用method : 'POST'设置 // 表单提交 ...

  2. Ext修改所有Ajax的timeout

    Ext修改所有Ajax的timeout stackoverflow上的解决方案 //需要在初始化viewport时执行 //方法一重写 Ext.Ajax.timeout= 60000; Ext.ove ...

  3. MVVM模式下 修改 store的ajax请求url。

    MVVM模式下 修改 store的ajax请求url. view.down('Pro').getViewModel().getStore('xx_store').proxy.url = "s ...

  4. EXT.JS6中的model,store,proxy的一些用法

    //one-to-one Ext.define('Address', { extend: 'Ext.data.Model', fields: [ 'address', 'city', 'state', ...

  5. 【翻译】Ext JS 4——Ajax和Rest代理处理服务器端一场和消息的方法

    原文:EXTJS4 - Handle Server-side exceptions and message from an Ajax or Rest proxy 作者:Raja 可能要处理的情况:su ...

  6. Sencha Touch 2.2 Store Proxy 异常监控

    移动端到服务端通信往往会发生很多莫名的异常情况,如何有效的监控proxy异常,给用户友好的用户体验呢? Proxy给我提供了异常exception的监听事件,只需要监控该项目即可. Sencha To ...

  7. Ext.store.load callback

    var paramsReceivable = {};                paramsReceivable.querytext = Ext.getCmp('hiddquerytext').g ...

  8. Ext 怎么发ajax请求

    Ext3.3完整包 Ext3.3中文文档 数据表的结构是:数据表table  > 记录record > 字段 store的结构是:  Ext.data.Store > Ext.dat ...

  9. ExtJS笔记 Proxy

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

随机推荐

  1. /-- Encapsulated exception ------------\ java.lang.NoSuchMethodException: com.sjzdaj.po.Class.setN_id([Ljava.lang.String;)

    转自:http://ruinxdgzy.iteye.com/blog/805138

  2. CentOS启动报错:Centos kernel panic-not syncing:VFS:Unable to mount root fs on unknown block

    Centos kernel panic-not syncing:VFS:Unable to mount root fs on unknown block 原因:主要问题就是你更新了内核之后出现的问题. ...

  3. git 克隆本地仓库

    如果要从本地仓库克隆到另一个地方使用如下命令 git clone d:/SourceRepository d:/DestinationRepository d:/SourceRepository:本地 ...

  4. OpenCV学习(2)--基本数据结构

    OpenCV的基本数据结构 CvPoint:表示图像中的点 CvPoint2D32f:二维空间中的点 CvPoint3D32f:三维空间中的点 这些都是结构体,并不是C++语言中的类,所以他们的构造函 ...

  5. Java提高学习之Object类详解(1)

    转自:http://www.importnew.com/10304.html 问:什么是Object类? 答:Object类存储在java.lang包中,是所有java类(Object类除外)的终极父 ...

  6. centos安装中文支持(转)

    安装中文支持包. yum install fonts-chineseyum install fonts-ISO8859-2 -------- 一.安装中文支持方法1.在安装光盘中找到一下包进行安装.r ...

  7. 生成php所需要的APNS Service pem证书的步骤

    1.登录到 iPhone Developer Connection Portal 并点击 App IDs 2.创建一个不使用通配符的 App ID .通配符 ID 不能用于推送通知服务.例如,我们的i ...

  8. flexbox弹性盒子模型

    这几天在做移动端的web开发,遇到了一些问题,之前没有折腾过这方面的东西,这次好好吸收下 css3的flexbox--弹性盒子模型,这个盒模型决定了一个盒子在其他盒子中的分布方式及如何处理可用的空间. ...

  9. IOS 访问系统粘贴板

    粘贴板提供了一种核心OS特性,用于跨应用程序共享数据.用户可以跨应用来复制粘贴,也可以设置只在本应用中复制粘贴用来保护隐私. UIPasteboard类允许访问共享的设备粘贴板以及内容,下面代码返回一 ...

  10. Myeclipse普通工程转为Maven工程

    在SVN导出的Maven项目,或以前不是用Maven管理的项目想要转换成Maven项目,但Myeclipse中右键Configure 找不到(eclipse可行)Convert to maven pr ...