sencha touch2.3 跨域访问

本文介绍如何使用Sencha Touch框架通过JSONP方式加载远程数据。首先定义了一个包含六个字段的Person模型,接着创建了一个配置了JSONP代理的PersonStore,并指定了服务器端点和数据根属性。最后演示了如何加载数据并处理回调。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

参考文档

http://docs.sencha.com/touch/2.3.1/#!/api/Ext.data.proxy.JsonP

http://docs.sencha.com/touch/2.3.1/#!/guide/proxies


一、定义model

Ext.define("MOA.model.Person", {
	extend: "Ext.data.Model",
	
	config: {
	    fields: [
	        {name: "id", type: "string"},
	        {name: "psnImg", type: "string"},
	        {name: "psnName", type: "string"},
	        {name: "psnSex", type: "string"},
	        {name: "registrationCode", type: "string"},
	        {name: "tel", type: "string"}
	    ]
	}
});

代码解析:

fields中定义该类的字段和类型

二、定义Store

Ext.define("MOA.store.PersonStore",{
	extend: "Ext.data.Store",
	xtype: "personStore",
	
	config: {
	    model: "MOA.model.Person",
	    proxy: {
	    	type: "jsonp",
	    	url: "http://192.168.168.168:7777",
    		reader: {
                type: 'json',
                rootProperty: 'users'
            }
	    }
	}
});
代码解析:

1、model属性对应上面定义的model类

2、proxy 属性对应代理类

type属性的jsonp为Ext.data.proxy.JsonP类

url属性为请求数据的路径

reader属性中的rootProperty对应server端传回的数据的根属性


server端回传的数据格式如下:

{
    users: [
        {
            id: 1,
            name: "Ed Spencer",
            email: "ed@sencha.com"
        }
    ]
}
三、读取数据

var p = Ext.create('MOA.store.PersonStore');
		p.load({params : {
                           id : ""
                        },
			callback: function(records,operation,success){
				console.log(records);
			}
		});



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值