在前端開發中,我們經常需要處理樹形數據,而 Ext JS 正好提供了 Ext.data.TreeStore 來幫助我們處理樹形數據的增刪改查操作。而在處理樹形數據時,很多時候我們需要將樹形數據轉化為 JSON 格式,這時候就可以使用 Ext.JSON.encode() 方法來處理。下面我們一起來看看如何使用 Ext.JSON.encode() 方法來處理樹形數據。
首先,我們需要定義一個 TreeStore:
var store = Ext.create('Ext.data.TreeStore', { root: { text: '根節點', children: [ {text: '子節點1', leaf: true}, {text: '子節點2', leaf: true}, {text: '子節點3', leaf: true} ] } });
這里我們定義了一個名為 store 的 TreeStore,它包含一個名為 root 的節點,root 節點下面有三個子節點。接下來,我們使用 Ext.JSON.encode() 方法將整個樹形數據轉化為 JSON 格式:
var json = Ext.JSON.encode(store.getRootNode().data); console.log(json);
這里我們使用了 TreeStore 的 getRootNode() 方法來獲取根節點,然后通過 data 屬性獲取根節點的數據,最后使用 Ext.JSON.encode() 方法將數據轉化為 JSON 格式。
當然,我們也可以只將某個節點及其所有子節點轉化為 JSON 格式:
var json = Ext.JSON.encode(store.getRootNode().getChildAt(1).data); console.log(json);
這里我們使用了 TreeStore 的 getChildAt() 方法來獲取第二個子節點,然后再轉化為 JSON 格式。
通過 Ext.JSON.encode() 方法,我們可以方便地將樹形數據轉化為 JSON 格式,方便傳遞數據或存儲數據。