ホームページ >ウェブフロントエンド >jsチュートリアル >Extjs_javascript スキルのストア グループ化機能の使用方法の詳細な分析

Extjs_javascript スキルのストア グループ化機能の使用方法の詳細な分析

WBOY
WBOYオリジナル
2016-05-16 15:04:361284ブラウズ

プロジェクトの実践中に、特定のフィールドに従ってグリッド内のデータをグループ化するという要件に遭遇しました。もちろん、この関数は API で使用でき、誰でも見つけられるようにここにリストされています。

2 つの注意点:

1. ストアを作成するときは、グループ化する必要がある値である groupField 属性の値を設定する必要があります

例:

JavaScript コード

Ext.define('Person', { 
extend: 'Ext.data.Model', 
fields: ['name', 'sex'] 
}); 

このデータ モデルでは、性別ごとにグループ化する必要があります。その後、以下のストアを参照してください

JavaScript コード

var PersonStore = Ext.create('Ext.data.Store', { 
storeId: 'PersonStore', 
model: 'Person', 
groupField: 'sex', 
data: [{ 
name: 'hongmei li', 
sex: 'female' 
},{ 
name: 'san zhang', 
sex: 'male' 
},{ 
name: 'Jim Green', 
sex: 'male' 
},{ 
name: 'Lily', 
sex: 'female' 
},{ 
name: 'Lucy', 
sex: 'female' 
}] 
}); 

次に、グループ表示用の tpl を定義する必要があります

JavaScript コード

var groupingFeature= Ext.create('Ext.grid.feature.Grouping',{ 
groupHeaderTpl: 'sex: {name} ({rows.length} Item{[values.rows.length > 1 ? "s" : ""]})' 
});//注意其中{name}即为store中sex列所对应的值 

gridPanel のコードは次のとおりです: 機能を上で定義した groupingFeature として構成します

JavaScript コード

var grid = Ext.create('Ext.grid.Panel', { 
renderTo: Ext.getBody(), 
store: PersonStore, 
width: 600, 
height: 400, 
title: 'Person', 
features: [groupingFeature], 
columns: [{ 
text: 'Name', 
flex: 1, 
dataIndex: 'name' 
},{ 
text: 'sex', 
flex: 1, 
dataIndex: 'sex' 
}] 
}); 

レンダリングは次のとおりです:

もちろん、グループ化が実装された後は、gridPanel の性別列を表示する必要はありません。

なお、ストア内のデータが変更された場合、グループ化は正常に表示されますか?

ここで itemclick イベントをグリッドに追加します。コードは次のとおりです:

JavaScript コード

listeners:{ 
itemclick:function(thisview,record){ 
PersonStore.<span style="color:#ff0000;">add</span>([{name:"li",sex:"male"},{name:"zhang",sex:"female"}]); 
} 
} 

効果は以下の通りです


インターフェースが私たちが望むものではないことがわかりますが、どうすれば解決できますか? (最初の愚かな解決策は、gridPanel を削除し、破棄し、再ロードするというものでした) リスナーがイベントをリッスンできるようにコードにいくつかの変更を加えました

JavaScript コード

listeners:{ 
itemclick: function (thisview,record){ 
PersonStore.loadData([{name: "li" ,sex: "male" },{name: "zhang" ,sex: "female" }], true ); 
} 
} 

効果をもう一度見てください:


これは、ストア内のデータを動的に変更する場合、データを GridPanel の最後に追加する代わりに、グループ化も実装する必要があります。これら 2 つのコードの違いは主に、ストアにデータを追加する方法にあります。前者は add(record)、後者はloadData(records,[append])

です。

最初は、なぜ同じストアがデータを追加するのか理解できませんでしたが、効果は異なりました。公式ドキュメントの説明を参照してください。add()、新しい Model インスタンスは既存のコレクションの最後に追加されます。 (コレクションにデータを追加します。最後に) ふと、loadData がストアのルールに従ってデータをロードしていることに気づきました。

さらに、グループ内の最も古い行を削除する方法については、私自身で確認し、ドキュメントが実装されているので、ここで共有します。

//以前のリスナーのリスニング イベントを次のように変更します:

first([boolean group]) メソッドに注意してください。パラメータが渡されない場合、パラメータが true の場合、ストア グループがグループ名キーとともに返されます。グループ内の最初のデータ。1 つのデータは複数の値のオブジェクトです。男性のデータを取得したい場合は、personStore.first(true). Female を使用します。 .first(true).male

JavaScript コード

listeners:{ 
itemclick: function (thisview,record){ 
PersonStore.loadData([{name: "li" ,sex: "male" },{name: "zhang" ,sex: "female" }], true ); 
alert(PersonStore.first( true ).female.get( 'name' )); 

console.log(PersonStore.first( true ).female); 
PersonStore.remove(PersonStore.first( true ).female); 
// console.log(PersonStore.getAt(0));
} 
}

removedRecords がメモリを占有するのを防ぐために、この関数を実装することはできますが、方法は少し不格好です。誰かが良い方法を知っていれば、

コードを見てください:

listeners:{ 
itemclick:function(thisview,record){ 
PersonStore.loadData([{name:"li",sex:"male"},{name:"zhang",sex:"female"}],true); 
alert(PersonStore.first(true).female.get('name')); 
console.log(PersonStore.first(true)); 
PersonStore.remove(PersonStore.first(true).female); 
var recs = PersonStore.getRange(); 
console.log(recs); 
//PersonStore.removeAll(true);//这句有没有都可以 
PersonStore.loadRecords(recs);//重新load数据,内存中记录的removed掉的就没有了 
console.log(PersonStore); 
alert(PersonStore.getRemovedRecords.length);//这句alert结果为0 
// console.log(PersonStore.getAt(0)); 
} 
}

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。