ExtJs的Reader

Reader : 主要用于将proxy数据代理读取的数据按照不同的规则进行解析,讲解析好的数据保存到Modle中

结构图

Ext.data.reader.Reader 读取器的根类

Ext.data.reader.Json JSON格式的读取器

Ext.data.reader.Array 扩展JSON的Array读取器

Ext.data.reader.Xml XML格式的读取器

Writer

结构图

Ext.data.writer.Writer

Ext.data.writer.Json 对象被解释成JSON的形式传到后台

Ext.data.writer.Xml  对象被解释成XML的形式传到后台

1.     Json的读取器

  1. (function(){
  2. Ext.onReady(function(){
  3. var userData = {
  4. //total : 200,
  5. count:250,
  6. user:{
  7. userID:'1',
  8. name:'uspcat.com',
  9. orders:[
  10. {id:'001',name:'pen'},
  11. {id:'002',name:'book'}
  12. ]
  13. }
  14. };
  15. //定义model
  16. Ext.regModel("user",{
  17. fields:[
  18. {name:'userID',type:'string'},
  19. {name:'name',type:'string'}
  20. ],
  21. hasMany: {model: 'order'}    //定义有多个order的属性
  22. });
  23. Ext.regModel("order",{
  24. fields:[
  25. {name:'id',type:'string'},
  26. {name:'name',type:'string'}
  27. ],
  28. belongsTo: {type: 'belongsTo', model: 'user'}  //定义属于
  29. });
  30. var mproxy = Ext.create("Ext.data.proxy.Memory",{
  31. model:'user',
  32. data:userData,
  33. reader:{
  34. type:'json',
  35. root:'user',
  36. implicitIncludes:true,    //级联读取
  37. totalProperty:'count'
  38. //record :'info'//服务器返回的数据可能很复杂,用record可以删选出有用的数据信息,装在带Model中
  39. }
  40. });
  41. mproxy.read(new Ext.data.Operation(),function(result){
  42. var datas = result.resultSet.records;
  43. alert(result.resultSet.total);    //打印count
  44. Ext.Array.each(datas,function(model){
  45. alert(model.get('name'));
  46. });
  47. var user = result.resultSet.records[0];   //获取第一个用用数据
  48. var orders = user.orders();    //获取到用户中的orders集合
  49. orders.each(function(order){   //遍历orders集合
  50. alert(order.get('name'));
  51. });
  52. });
  53. });
  54. })();

2.     Array读取器

  1. Ext.onReady(function(){
  2. Ext.regModel("person",{
  3. fields:[
  4. 'name','age'
  5. //         {name:'name'},
  6. //         {name:'age'}
  7. ],
  8. proxy :{
  9. type:'ajax',
  10. url:'person.jsp',
  11. reader:{
  12. type:'array'
  13. }
  14. }
  15. });
  16. var person =Ext.ModelManager.getModel('person');
  17. person.load(1,{
  18. success:function(model){
  19. alert(model.get('name'));
  20. }
  21. });
  22. });

Person.jsp文件:

<%

response.getWriter().write("[['yunfengcheng',26]]");

%>

3. XML格式的读取器

  1. (function(){
  2. Ext.onReady(function(){
  3. Ext.regModel("user",{
  4. fields:[
  5. {name:'name'},
  6. {name:'id'}
  7. ],
  8. proxy:{
  9. type:'ajax',
  10. url:'users.xml',
  11. reader:{
  12. type:'xml',
  13. record:'user'
  14. }
  15. }
  16. });
  17. var user = Ext.ModelManager.getModel('user');
  18. user.load(1,{
  19. success:function(model){
  20. alert(model);
  21. alert(model.get('id'));
  22. }
  23. });
  24. });
  25. })();

Users.xml文件:

  1. <users>
  2. <user>
  3. <name>uspcat.com</name>
  4. <id>00101</id>
  5. </user>
  6. </users>

4.     writer的Json和xml

  1. Ext.onReady(function(){
  2. Ext.regModel("person",{
  3. fields:[
  4. 'name','age'
  5. ],
  6. proxy :{
  7. type:'ajax',
  8. url:'person.jsp',
  9. writer:{
  10. type:'json'  //使用Json提交数据
  11. //type:'xml' //使用xml提交数据
  12. }
  13. }
  14. });
  15. Ext.ModelMgr.create({
  16. name:'uspcat.con',
  17. age:1
  18. },'person').save();
  19. });

使用Json写入的时候,浏览器查看提交信息是如下图,是以json提交的:

使用xml写入的时候,浏览器查看提交信息是如下图,是以xml提交的:

原文链接:https://blog.csdn.net/hanhan313/article/details/8159774

ExtJs的Reader的更多相关文章

  1. ExtJS笔记 Reader

    Readers are used to interpret data to be loaded into a Model instance or a Store - often in response ...

  2. EXTJS之DATA PROXY READER

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

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

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

  4. [转]ExtJS Grid 分页时保持选中的简单实现方法

    原文地址 :http://www.qeefee.com/article/ext-grid-keep-paging-selection ExtJS中经常要用到分页和选择,但是当选择遇到分页的时候,杯具就 ...

  5. ExtJs基础知识总结:自定义弹窗和ComboBox自动联想加载(四)

    概述 Extjs弹窗可以分为消息弹窗.对话框,这些弹窗的方式ExtJs自带的Ext.Msg.alert就已经可以满足简单消息提示,但是相对复杂的提示,比如如何将Ext.grid.Panel的控件显示嵌 ...

  6. ExtJS基础知识总结:自定义日历和ComboBox控件(二)

    概述 1.ExtJS 5不支持日期选择框中只选择年月,为了满足ExtJs5可以实现选择年月的功能,查询网上资料,整理出来了相应的处理方式,最终实现的效果如下图: 2.ExtJS 控件丰富,如果需要实现 ...

  7. extjs 学习小窍门

    一.从form中获取field的三个方法: 1.Ext.getCmp('id'); 2.FormPanel.getForm().findField('id/name'); 3.Ext.get('id/ ...

  8. Extjs 源码组成(4.0.7)

    (function(){})()形式的自执行,构建Ext对象(0~584) 1  设置全局对象EXt:global.Ext = {}, 2 实现了Ext对象面向对象编程的基础方法,如,apply,ex ...

  9. ExtJs 之 ComboBox级联使用

    刚接触ExtJs不到一周,项目使用ExtJs框架,有个版块用到了combobox的级联(两级),遇到了一系列的问题,两天来一直查API.网络资料,终于解决了. 先列出遇到的一系列问题(也许你也遇到过! ...

随机推荐

  1. hdu4336 Card Collector 【最值反演】

    题目链接 hdu4336 题解 最值反演 也叫做\(min-max\)容斥,在计算期望时有奇效 \[max\{S\} = \sum\limits_{T \in S} (-1)^{|T| + 1}min ...

  2. wazhu之agent功能详解

      一.日志数据收集 日志数据收集是从服务器或设备生成的记录中收集的实时过程.此组件可以通过文本文件或Windows事件日志接收日志.它还可以通过远程syslog直接接收日志,这对防火墙和其他此类设备 ...

  3. supervisor 添加新配置不生效的问题

    supervisorctl reread supervisorctl reload (不运行这一步会导致启动不了) supervisorctl start xxx:* 提示:No config upd ...

  4. NATS_01:NATS基础介绍

    1.介绍 NATS(Message bus): 从CloudFoundry的总架构图看,位于各模块中心位置的是一个叫nats的组件.NATS是由CloudFoundry的架构师Derek开发的一个开源 ...

  5. GO_02:GO语言开篇

    Go的发展史 Go 是一个开源的编程语言,它能让构造简单.可靠且高效的软件变得容易. Go是从2007年末由Robert Griesemer, Rob Pike, Ken Thompson主持开发,后 ...

  6. python中高阶函数与装饰器(3)

    >>> f = lambda x: x * x>>> f<function <lambda> at 0x101c6ef28> >> ...

  7. 何凯文每日一句打卡||DAY1~DAY3

    01长难句 In an open meeting with congressional Democrats and Republicans, Trump embraced raising the ag ...

  8. 【转】Graphics.DrawImage 方法 IntPtr 结构 GDI 句柄 知识收集

    Graphics.DrawImage 方法 在指定的位置使用原始物理大小绘制指定的 Image. 命名空间:System.Drawing 程序集:System.Drawing(在 system.dra ...

  9. CentOS Linux 7 安装教程

    建立新的虚拟机 将CentOS 7 ISO文件插入到CD-Rom 启动虚拟机,F12选择启动方式为CD/DVD 选择Install CentOS Linux 7 加载安装必要文件 选择安装过程所显示的 ...

  10. Ubuntu: HDF5报错: HDF5 header version与HDF5 library不匹配

    今天在执行一个用到hdf5的python脚本时,遇到如下错误 Warning! ***HDF5 library version mismatched error*** The HDF5 header ...