Extjs-数据存储与传输-记录集 Ext.data.Record

来源:互联网 发布:zip解压软件下载mac 编辑:程序博客网 时间:2024/05/17 15:05

1.Ext.data.Record

是一个设定了内部数据类型的对象,是Ext.data.Store的最基本组成部分,如果把Ext.data.Store看作二维表,Ext.data.Record就是每一行对应的实例,Ext.data.Record主要功能是保存数据,并在内部数据发生改变时记录修改的状态,还可以保留修改之前的原始值,使用Ext.data.Record时通常都是由create()函数开始的

首先用create()函数创建一个自定义的Record类型

<script type="text/javascript" defer>Ext.onReady(function(){//MyRecord是新定义的类型,包含字符串类型name,整数类型agevar MyRecord = new Ext.data.Record.create([{name : 'name',type : 'string'},{name : 'age',type : 'int'}]);//创建对象时,可以通过构造方法对对象赋值var boy = new MyRecord({name : 'lwc',age : 25});//我们得到实例boy,使用三种方法得到name属性alert(boy.data.name);alert(boy.data['name']);alert(boy.get('name'));//如果需要需改boy中的数据,不要直接操作data,应该用set()函数boy.data.name='wr';//不建议使用,因为record无法记录属性数据boy.set('name','wr')/*set()函数会判断属性值是否发生改变,如果改变就将当前对象的dirty属性设置为true,就修改前的原始值放入modified对象中*/});</script>

2.在Record的属性数据被修改后,可以执行一下操作

commit()提交:这个函数的效果是设置dirty为false,并且删除modified中保存的原始数据reject()撤销:这个函数的效果是将data中已经修改了的属性恢复成modified中保存的原始数据,然后将dirty设置为falsegetChanges()获取修改的部分:这个函数会把data中经过修改的属性和数据放在一个JSON对象里并且返回,还可以调用isModified()判断当前record中的数据是否被修改,Ext.data.Record还提供了用于复制record实例的函数copy()
var copy = boy.copy();
copy函数不能复制dirty和modified的属性值
原创粉丝点击