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. 【bzoj4542】 Hnoi2016—大数

    http://www.lydsy.com/JudgeOnline/problem.php?id=4542 (题目链接) 题意 给出一个素数$P$,一个数串$S$,$m$个询问,每次询问区间$[l,r] ...

  2. 解题:SDOI 2017 数字表格

    题面 反演题,推式子么=.= $\prod\limits_{d=1}^{min(n,m)}\prod\limits_{i=1}^n\prod\limits_{j=1}^m[gcd(i,j)==d]fi ...

  3. Linux crontab 命令格式与举例

    每五分钟执行  */5 * * * * 每小时执行     0 * * * * 每天执行        0 0 * * * 每周执行       0 0 * * 0 每月执行        0 0 1 ...

  4. HDU--4705

    题目: Y 原题链接:http://acm.hdu.edu.cn/showproblem.php?pid=4705 分析:树形dp的思想,枚举中间点. #include<iostream> ...

  5. 五、Linux学习之文件搜索命令

    一.文件搜索命令locate locate 文件名 在后台数据库中按文件名搜索,搜索速度最快 /var/lib/mlocate #locate命令所搜索的后台数据库(数据库不会实时刷新,所以新建的文件 ...

  6. IOS取消performSelector警告

    #pragma clang diagnostic push #pragma clang diagnostic ignored "-Warc-performSelector-leaks&quo ...

  7. 5 Kafka 应用问题经验积累

    16.Kafka 配置文件同步 为了给kafka的进程添加GC日志信息,方便在以后重启的时候,加入GC日志: 修改bin/kafka-server-start.sh: export KAFKA_OPT ...

  8. Nginx模块Lua-Nginx-Module学习笔记(一)Nginx Lua API 接口详解

    源码地址:https://github.com/Tinywan/Lua-Nginx-Redis 一.介绍 各种* _by_lua,* _by_lua_block和* _by_lua_file配置指令用 ...

  9. 权限 mock location

    1.集成环信的时候,该权限报错: mock location权限是是“允许程序创建模拟位置”,主要是提供用于测试.打包的时候并不需要,所以解决办法分两步: 1.声明tools 2.添加忽略:

  10. 【BZOJ】1828: [Usaco2010 Mar]balloc 农场分配(经典贪心)

    [算法]贪心+线段树 [题意]给定n个数字ci,m个区间[a,b](1<=a,b<=10^5),每个位置最多被ci个区间覆盖,求最多选择多少区间. 附加退化问题:全部ci=1,即求最多的不 ...