這篇文章將為大家詳細講解有關Ext.js4.2.1中Ext.data.Record是什么,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。
Ext.data.Record就是一個設定了內部數據類型的對象,它是Ext.data.Store的最基本組成部分。如果把Ext.data.Store看作是一張二維表,那么它的每一行就對應一個Ext.data.Record實例。
Ext.data.Record的主要功能是保存數據,并且在內部數據發生改變時記錄修改的狀態,它還可以保留修改之前的原始值。
我們使用Ext.data.Record時通常都是由create()函數開始,首先用create()函數創建一個自定義的Record類型,如下面的代碼所示:
var PersonRecord = Ext.data.Record.create([
{name: 'name', type: 'string'},
{name: 'sex', type: 'int'}
]);
PersonRecord就是我們定義的新類型,包含字符串類型的name和整數類型的sex兩個屬性,然后我們使用new關鍵字創建PersonRecord的實例,如下面的代碼所示:
var boy = new PersonRecord({
name: 'boy',
sex: 0
});
創建對象時,可以直接通過構造方法為對象賦予初始值,將'boy'賦值給name,0賦值給sex。
現在,我們得到了PersonRecord的實例boy,如何才能得到它的屬性呢?以下三種方式都可以獲得boy中name屬性的數據,如下面的代碼所示:
alert(boy.data.name);
alert(boy.data['name']);
alert(boy.get('name'));
這里涉及Ext.data.Record的data屬性,這是定義在Ext.data.Record中的一個公共屬性,用于保存當前record對象的所有數據。它是一個JSON對象,可以直接從它里面獲得需要的數據??梢酝ㄟ^Ext.data.Record的get()函數方便地從data屬性中獲得指定的屬性。
如果我們需要修改boy中的數據,請不要使用以下方式直接操作data,如下面的代碼所示:
boy.data.name = 'boy name';
boy.data['name'] = 'boy name';
而應該使用set()函數,如下面的代碼所示:
boy.set('name', 'body name');
set()函數會判斷屬性值是否發生了改變,如果改變了,就要將當前對象的dirty屬性設置為true,并將修改之前的原始值放入
modified對象中,供其他函數使用。如果直接操作data中的值,record就無法記錄屬性數據的修改情況。
Record的屬性數據被修改后,我們可以執行如下幾種操作。
commit()(提交):這個函數的效果是設置dirty為false,并刪除modified中保存的原始數據。
reject()(撤銷):這個函數的效果是將data中已經修改了的屬性值都恢復成modified中保存的原始數據,然后設置dirty為false,并刪除保存原始數據的modified對象。
getChanges()獲得修改的部分:這個函數會把data中經過修改的屬性和數據放在一個JSON對象里并返回。例如上例中,getChanges()返回的結果是{name:’body name’}。
我們還可以調用isModified()判斷當前record中的數據是否被修改。
Ext.data.Record還提供了用于復制record實例的函數copy()。
var copyBoy = boy.copy();
這樣我們就得到了boy的一個副本,它里面包含了boy的data數據,但copy()函數不會復制dirty和modified等額外的屬性值。
關于“Ext.js4.2.1中Ext.data.Record是什么”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。