`
zengshaotao
  • 浏览: 791906 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

extjs4数据模型

 
阅读更多

1、创建Ext.data.Model数据实体模型 

Javascript代码  收藏代码
  1. //注册用户数据模型User  
  2. Ext.regModel('User', {  
  3.     fields: [//定义模型字段  
  4.         {name: 'name',  type: 'string'},  
  5.         {name: 'age',   type: 'int'},  
  6.         {name: 'phone', type: 'string'}  
  7.     ]  
  8. });  
  9. //创建User模型的实体对象  
  10. var user = Ext.ModelMgr.create({  
  11.     name : 'tom',  
  12.     age  : 24,  
  13.     phone: '555-555-5555'  
  14. }, 'User');  
  15. //获取员工姓名  
  16. alert(user.get('name'));  



2、在模型中进行数据验证 

Javascript代码  收藏代码
  1. //定义默认的验证提示信息  
  2. Ext.data.validations.presenceMessage = '必须是有效值。';  
  3. Ext.data.validations.lengthMessage = '长度错误。';  
  4. Ext.data.validations.formatMessage = '格式错误。';  
  5. Ext.data.validations.inclusionMessage = '没有包括在可接受的数据中。';  
  6. Ext.data.validations.exclusionMessage = '不是可接受的值。';  
  7.   
  8. //自定义数值范围验证  
  9. Ext.apply(Ext.data.validations,{  
  10.     number : function(config, value){  
  11.         if (value === undefined) {  
  12.             return false;  
  13.         }  
  14.         var min    = config.min,  
  15.             max    = config.max;  
  16.       
  17.         if ((min && value < min) || (max && value > max)) {  
  18.             return false;  
  19.         } else {  
  20.             return true;  
  21.         }  
  22.     },  
  23.     numberMessage : '数值范围错误。'  
  24. });  
  25.   
  26. //注册用户数据模型User  
  27. Ext.regModel('User', {  
  28.     fields: [//定义模型字段  
  29.          {name: 'name',     type: 'string'},  
  30.          {name: 'age',      type: 'int'},  
  31.          {name: 'phone',    type: 'string'},  
  32.          {name: 'gender',   type: 'string'},  
  33.          {name: 'username', type: 'string'},  
  34.          {name: 'alive',    type: 'boolean', defaultValue: true}  
  35.     ],  
  36.     validations: [  
  37.         {type: 'presence',  field: 'age'},  
  38.         {type: 'number',  field: 'age', min : 30},  
  39.         {type: 'length',    field: 'name', min: 2},  
  40.         {type: 'inclusion', field: 'gender',   list: ['男''女']},  
  41.         {type: 'exclusion', field: 'username', list: ['admin@xx.xx''user@xx.xx']},  
  42.         {type: 'format',    field: 'username',  
  43.             //校验用户名是否为电子邮件格式  
  44.             matcher: /^([\w]+)(.[\w]+)*@([\w-]+\.){1,5}([A-Za-z]){2,4}$/  
  45.         }  
  46.     ]  
  47. });  
  48. //创建User模型的实体对象  
  49. var user = Ext.ModelMgr.create({  
  50.     name : 'tom',  
  51.     age  : 24,  
  52.     gender : 'man',  
  53.     username: 'abc'  
  54. }, 'User');  
  55. //执行数据验证  
  56. var errors = user.validate();  
  57. //获取验证信息  
  58. var message = [];  
  59. errors.each(function(v){  
  60.     message.push(v.field+' : '+v.message)  
  61. });  
  62. alert(message.join('\n'));  



3、在模型中通过代理加载数据 

Javascript代码  收藏代码
  1. //注册用户数据模型User  
  2. Ext.regModel('User', {  
  3.     fields: [//定义模型字段  
  4.             {name: 'name', type: 'string'},  
  5.             {name: 'age', type: 'int'},  
  6.             {name: 'id', type: 'int'}  
  7.     ],  
  8.     //配置数据代理  
  9.     proxy: {  
  10.         type : 'ajax',  
  11.         url : 'userServer.jsp'  
  12.     }  
  13. });  
  14. var user = Ext.ModelManager.getModel('User');  
  15. //通过代理读取数据  
  16. user.load(1, {  
  17.     success: function(rec) {  
  18.         alert(rec.get('name'));  
  19.     }  
  20. });  
Jsp代码  收藏代码
  1. <%@ page language="java" contentType="text/html; charset=utf-8" pageEncoding="utf-8"%>  
  2. <%@ page import="java.util.*" %>  
  3. <%  
  4. String userId = request.getParameter("id");  
  5. response.setContentType("application/json;charset=UTF-8");  
  6. response.getWriter().write("{id : "+userId+", name: 'user"+userId+"'}");  
  7. %>  



4、模型间的一对多关系 

Javascript代码  收藏代码
  1. //注册用户数据模型User  
  2. Ext.regModel('User', {  
  3.     fields: [//定义模型字段  
  4.             {name: 'name', type: 'string'},//用户名称  
  5.             {name: 'id', type: 'int'}//用户id  
  6.     ],  
  7.     //User与Product是一对多关系  
  8.     hasMany: {model: 'Product', name:'getProducts',autoLoad : false},  
  9.     proxy: {  
  10.         type : 'ajax',   
  11.         url : 'userServer.jsp'  
  12.     }  
  13. });  
  14. //注册产品数据模型Product  
  15. Ext.regModel('Product', {  
  16.     fields: [//定义模型字段  
  17.             {name: 'id', type: 'int'},//产品id  
  18.             {name: 'title', type: 'string'},//产品名称  
  19.             {name: 'user_id', type: 'int'}//用户id  
  20.     ],  
  21.     proxy: {  
  22.         type : 'ajax',  
  23.         url : 'ProductServer1.jsp',  
  24.         reader: {  
  25.             type: 'json',  
  26.             root: 'products'  
  27.         }  
  28.     }  
  29. });  
  30. //创建User实例  
  31. var user = Ext.ModelManager.getModel('User');  
  32. //读取id为1的User实例  
  33. user.load(1, {  
  34.     success: function(rec) {  
  35.         //获取user_id为1的产品Store  
  36.         var products = rec.getProducts();  
  37.         //加载user_id为1的产品数据  
  38.         products.load({  
  39.             callback : function(records, operation, success){  
  40.                 var msg = [];  
  41.                 for(var i = 0; i < records.length; i++){  
  42.                     var rec = records[i];  
  43.                     msg.push('产品名称:'+rec.get('title')+' 用户id:'+rec.get('user_id'));  
  44.                 }  
  45.                 alert(msg.join('\n'));  
  46.             }  
  47.         });  
  48.     }  
  49. });  

ProductServer1.jsp

Jsp代码  收藏代码
  1. <%@ page language="java" contentType="text/html; charset=utf-8" pageEncoding="utf-8"%>  
  2. <%@ page import="net.sf.json.JSONObject" %>  
  3. <%@ page import="net.sf.json.JSONArray" %>  
  4. <%  
  5. String filter = request.getParameter("filter");  
  6. JSONArray filters = JSONArray.fromObject(filter);  
  7. int userId = filters.getJSONObject(0).getInt("value");  
  8. response.setContentType("application/json;charset=UTF-8");  
  9. String result = "{products:[{id : 1, title: '产品1', user_id : "+userId+"}, {id : 2, title: '产品2', user_id : "+userId+"}]}";  
  10. System.out.println("result="+result);  
  11. response.getWriter().write(result);  
  12. %>  



5、模型间的多对一关系 

Javascript代码  收藏代码
  1. //注册分类数据模型Category  
  2. Ext.regModel('Category', {  
  3.     fields: [//定义模型字段  
  4.             {name: 'type', type: 'string'},//产品类型名称  
  5.             {name: 'id', type: 'int'}//产品类型id  
  6.     ],  
  7.     proxy: {  
  8.         type : 'ajax',   
  9.         url : 'CategoryServer.jsp'  
  10.     }  
  11. });  
  12. //注册产品数据模型Product  
  13. Ext.regModel('Product', {  
  14.     fields: [//定义模型字段  
  15.             {name: 'id', type: 'int'},//产品id  
  16.             {name: 'title', type: 'string'},//产品名称  
  17.             {name: 'category_id', type: 'int'}//用户id  
  18.     ],  
  19.     belongsTo : 'Category'  
  20. });  
  21. //创建product实例  
  22. var product = new Product({  
  23.     id: 100,  
  24.     category_id: 1,  
  25.     title: '产品1'  
  26. });  
  27. product.getCategory(function(category, operation){  
  28.     //获取类型名称  
  29.     alert(category.get('type'));  
  30. });  
Jsp代码  收藏代码
  1. <%@ page language="java" contentType="text/html; charset=utf-8" pageEncoding="utf-8"%>  
  2. <%  
  3. String categoryId = request.getParameter("id");  
  4. response.setContentType("application/json;charset=UTF-8");  
  5. response.getWriter().write("{id : "+categoryId+", type: '产品类型"+categoryId+"'}");  
  6. %>  



6、Ext.data.proxy.Memory示例 

Javascript代码  收藏代码
  1. //创建数据模型  
  2. Ext.regModel('User', {  
  3.     fields: ['id','name','age']  
  4. });  
  5.   
  6. //定义内存数据变量  
  7. var userData = {  
  8.     users : [  
  9.         { id: 1, name: '张三', age: 20 },  
  10.         { id: 2, name: '李四', age: 30 },  
  11.         { id: 3, name: '王五', age: 40 }  
  12.     ]  
  13. };    
  14.   
  15. //创建memory代理  
  16. var memoryProxy = new Ext.data.proxy.Memory({  
  17.     model : 'User',  
  18.     reader: {  
  19.         root: 'users'  
  20.     },  
  21.     data : userData  
  22. });           
  23.   
  24. //读取数据  
  25. memoryProxy.read(new Ext.data.Operation(), callBack)  
  26. //数据读取之后的回调函数  
  27. function callBack(result){      //load方法的回调函数  
  28.     var totalRecords = result.resultSet.total;  
  29.     alert('读取内存数据,记录总是:'+totalRecords);  
  30. }  



7、Ext.data.proxy.Ajax示例 

Javascript代码  收藏代码
  1. //创建数据模型  
  2. Ext.regModel('Person', {  
  3.     fields: ['name','age']  
  4. });  
  5. //创建Ajax代理  
  6. var ajaxProxy = new Ext.data.proxy.Ajax({  
  7.     url : 'personServer.jsp',  
  8.     model: 'Person',  
  9.     reader: 'json'  
  10. });  
  11. //创建请求参数对象  
  12. var operation = new Ext.data.Operation({  
  13.     action: 'read'//设置请求动作为read  
  14. });  
  15. //读取数据  
  16. ajaxProxy.doRequest(operation,callBack);  
  17. //doRequest方法的回调函数  
  18. function callBack(operation){  
  19.     //获取原始响应数据  
  20.     var responseText = operation.response.responseText;  
  21.     //获得记录总数  
  22.     var totalRecords = operation.resultSet.totalRecords;  
  23.     //获得记录数组  
  24.     var records = operation.resultSet.records;  
  25.       
  26.     alert('使用Ajax代理读取远程数据,记录总是:'+totalRecords);  
  27. }  
Jsp代码  收藏代码
  1. <%@ page language="java" contentType="text/html; charset=utf-8" pageEncoding="utf-8"%>  
  2. <%  
  3.     response.setContentType("application/json;charset=UTF-8");  
  4.     String result = "[{name: '张三', age : 20}, {name: '李四', age : 30}]";  
  5.     response.getWriter().write(result);  
  6. %>  



8、Ext.data.reader.Json示例 

Javascript代码  收藏代码
  1. //JSON格式的用户及订单信息  
  2. var userData = {  
  3.     "total" : 2000,  
  4.     "users": [{  
  5.         "id": 123,  
  6.         "name""张三",  
  7.         "orders": [{  
  8.             "id": 50,  
  9.             "total" : 100  
  10.         }]  
  11.     }]  
  12. }  
  13. //定义用户User模型  
  14. Ext.regModel("User", {  
  15.     fields: [ 'id''name' ],  
  16.     hasMany: 'Order'//定义User与Order之间的一对多关系  
  17. });  
  18. //定义订单Order模型  
  19. Ext.regModel("Order", {  
  20.     fields: [ 'id''total' ],  
  21.     belongsTo: 'User'//定义Order与User之间的多对一关系  
  22. });  
  23.   
  24. //创建memory代理  
  25. var memoryProxy = new Ext.data.proxy.Memory({  
  26.     model : 'User',  
  27.     reader: {  
  28.         type: 'json',//Ext.data.reader.Json读取器  
  29.         root: 'users'  
  30.     },  
  31.     data : userData  
  32. });   
  33. //读取数据  
  34. memoryProxy.read(new Ext.data.Operation(), callBack)  
  35. //数据读取之后的回调函数  
  36. function callBack(result){  
  37.     //获取总记录数  
  38.     var count = result.resultSet.total;  
  39.     //获取第一个用户信息  
  40.     var user = result.resultSet.records[0];  
  41.     //获取该用户的第一个账单信息  
  42.     var order = user.orders().getAt(0);  
  43.     alert('总记录数:'+count+  
  44.           '\n姓名:'+user.get('name')+  
  45.           '\n账单金额:'+order.get('total'));  
  46. }  



9、读取复杂的JSON数据 

Javascript代码  收藏代码
  1. //JSON格式的用户及订单信息  
  2. var userData = {  
  3.     "users": [{  
  4.         "searchDate" : "2011-04-24",//查询时间  
  5.         "role" : "admin",//查询人角色  
  6.         "info" : {  
  7.             "id": 123,  
  8.             "name""张三"  
  9.         }  
  10.     }]  
  11. }  
  12. //定义用户User模型  
  13. Ext.regModel("User", {  
  14.     fields: [ 'id''name' ]  
  15. });  
  16.   
  17. //创建memory代理  
  18. var memoryProxy = new Ext.data.proxy.Memory({  
  19.     model : 'User',  
  20.     reader: {  
  21.         type: 'json',//Ext.data.reader.Json读取器  
  22.         root: 'users',  
  23.         record : 'info'//定位有效数据的位置  
  24.     },  
  25.     data : userData  
  26. });   
  27. //读取数据  
  28. memoryProxy.read(new Ext.data.Operation(), callBack)  
  29. //数据读取之后的回调函数  
  30. function callBack(result){  
  31.     //获取第一个用户信息  
  32.     var user = result.resultSet.records[0];  
  33.     alert('姓名:'+user.get('name'));  
  34. }  



10、Ext.data.Store示例 

Javascript代码  收藏代码
  1. //定义用户User模型  
  2. Ext.regModel("User", {  
  3.     fields: ['name''age' ],  
  4.     proxy: {  
  5.         type: 'memory'  
  6.     }  
  7. });  
  8. //创建数据集对象  
  9. var myStore = new Ext.data.Store({  
  10.     autoLoad: true,  
  11.     data : [{name: '张三', age : 20},   
  12.             {name: '李四', age : 30}],  
  13.     model: 'User'  
  14. });  
  15. //遍历Store中的记录  
  16. var msg = ['遍历Store中的记录:'];  
  17. myStore.each(function(rec){  
  18.     msg.push('姓名:'+rec.get('name')+' 年龄:'+rec.get('age'));  
  19. });  
  20. alert(msg.join('\n'));  



11、Ext.data.ArrayStore示例 

Javascript代码  收藏代码
  1. //定义用户User模型  
  2. Ext.regModel("User", {  
  3.     fields: ['name''age' ],  
  4.     proxy: 'memory'  
  5. });  
  6. //创建ArrayStore数据集对象  
  7. var myStore = new Ext.data.ArrayStore({  
  8.     autoLoad: true,  
  9.     data : [['张三',20],['李四',30]],//数组数据  
  10.     model: 'User'  
  11. });  
  12. //遍历Store中的记录  
  13. var msg = ['遍历ArrayStore中的记录:'];  
  14. myStore.each(function(rec){  
  15.     msg.push('姓名:'+rec.get('name')+' 年龄:'+rec.get('age'));  
  16. });  
  17. alert(msg.join('\n'));  
分享到:
评论

相关推荐

    ExtJS4 2学习 21 动态菜单与表格数据展示操作总结篇

    1. 创建`Ext.data.Store`实例,定义数据模型和数据源,可以是JSON对象、XML文件或远程API。 2. 使用`Ext.grid.column.Column`配置列的显示,包括字段名、标题、宽度等属性。 3. 配置`grid.Panel`,指定数据存储、列...

    extjs4中文文档

    3. **数据绑定**:EXTJS4支持双向数据绑定,使得视图与模型之间的数据同步变得简单,大大减少了手动更新视图的工作。 4. **高级表格和网格**:EXTJS4的GridPanel组件提供强大的数据展示和操作功能,支持分页、排序...

    EXTJS4.0数据模型

    随便上传的一个阅读文档。不要随便下载!呵呵!试试看吧!

    Extjs4 grid使用例子

    在这个例子中,Model定义了数据模型,View负责呈现数据,而Controller作为中间人,处理用户交互和数据更新。 2. **Grid组件**: Grid组件是ExtJS的核心组件之一,用于展示结构化数据。它提供了诸如分页、排序、...

    ExtJs4.rar

    其次,数据绑定和模型层的强化是ExtJS4的另一大亮点。新版本引入了Model、Store和Proxy的概念,它们共同构建了一个强大的数据管理框架。Model用于定义数据结构和验证规则,Store则作为数据容器,负责加载、存储和...

    extjs4Mvc事例

    5. **ViewModel(视图模型)**:虽然在ExtJS 4中不是必需的,但ViewModel是推荐的最佳实践,特别是在数据绑定变得复杂的场景下。ViewModel提供了一种方式来链接模型数据和视图组件,使得数据可以直接在视图中呈现,...

    extjs4mvc的crud

    在ExtJS 4中,模型负责数据管理,视图负责用户界面展示,而控制器则作为两者之间的桥梁,处理用户的交互并协调数据流动。 在货物处理的CRUD操作中: 1. **创建(Create)**:当用户输入新货物信息时,这些信息会被...

    extjs最简单的数据绑定和修改

    在ExtJS中,数据模型定义了数据对象的结构和属性。创建一个模型类,比如`Ext.define('User', {extend: 'Ext.data.Model', fields: ['name', 'email']})`,其中`fields`数组定义了模型的属性名。 2. 数据存储...

    ExtJS4 doc文档

    ExtJS4的数据管理是基于MVC(模型-视图-控制器)架构的,提供了一种结构化的方式来处理和显示数据。`Store`对象是数据的核心,它可以加载和存储数据,与视图进行绑定。此外,`Model`定义了数据字段和验证规则,而`...

    Extjs4 图片浏览器

    6. **Data Binding(数据绑定)**:ExtJS4的一个重要特性,允许UI元素与后台数据模型实时同步,当选择新的图片时,ImageViewer会自动更新以显示新图片。 7. **Events(事件)**:通过监听用户的交互行为,如点击...

    extjs4 treeGrid实例

    总的来说,ExtJS4 TreeGrid实例的创建涉及模型定义、数据存储、列配置和面板创建等多个环节,能够有效地呈现层次结构的报表数据,提供丰富的用户交互体验。在实际应用中,你可能需要根据具体需求调整和扩展这个基础...

    extjs4MVC实现

    - Models:在 ExtJS 中,模型定义了数据对象的结构和验证规则。它们与服务器端的数据接口进行通信,负责数据的获取和更新。 - Stores:存储器是模型的集合,用于管理一组模型实例,提供数据的加载、排序、过滤等...

    extjs4_权限系统

    2. **经销商模型.erwin** - 另一个Erwin文件,可能描述了系统中与经销商相关的数据模型,这可能意味着系统支持多级分销或者合作伙伴管理。 3. **authority_data.sql** 和 **authority.sql** - 这两个SQL文件可能...

    ExtJS4 MVC 混合实例

    通过Ext.data.Model类,你可以定义一个数据模型,并使用Store来管理这些模型实例,实现数据的加载、保存和同步。 2. **视图(View)**:视图负责显示数据和响应用户交互。在ExtJS中,视图通常是组件(Component)...

    EXTJS4开发的图片文章管理项目实例

    "DB"文件夹下的建表语句是初始化数据库结构的关键,可以了解到系统数据模型的设计。 为了实现图片上传功能,EXTJS4提供了一种叫做FileField的组件,它支持文件选择和上传。后台JAVA服务接收这些文件,通常会将其...

    extjs4官方示例以及api文档html版

    "Ext.data.Model"定义了数据模型,与后端数据进行交互的基础。在阅读API时,注意理解类的继承关系、配置项的作用以及事件监听的使用。 在实际开发中,部署环境的选择也非常重要。虽然EXTJS4的示例可以在本地运行,...

    extjs4环境搭建

    在`Ext.onReady`的回调函数内,你可以编写代码来实例化窗口、面板、表格等组件,定义数据模型和数据存储,以及设置布局和事件监听器。 总结起来,搭建ExtJS4开发环境主要包括以下几个步骤: 1. 下载并解压ExtJS4的...

    EXTJS4+STRUTS2+JAVA增删改查

    在这个"EXTJS4+STRUTS2+JAVA增删改查"的例子中,我们将深入探讨这三个技术如何协同工作,实现数据的动态管理。 EXTJS4是一个强大的JavaScript库,主要用于创建桌面级的Web应用程序。它提供了丰富的组件库,如表格、...

    Extjs学习笔记之九 数据模型(上)

    ### Extjs 学习笔记之九:数据模型(上) ...以上内容仅为Extjs数据模型的基础介绍。接下来的文章中,我们将继续深入探讨数据解析器(DataReader)和数据集(Store),以及它们在实际项目中的应用技巧。

    extjs4学习资源大全

    在实际项目中,你可能还会遇到数据加载、异步通信(使用Ajax)和状态管理等问题,ExtJS4提供了解决这些问题的强大工具,如Store和Proxy。同时,不要忽视性能优化,合理使用组件配置和内存管理技巧,可以使你的应用...

Global site tag (gtag.js) - Google Analytics