DC.js - Pengantar Crossfilter
Crossfilter adalah dataset multi-dimensi. Ini mendukung interaksi yang sangat cepat dengan kumpulan data yang berisi satu juta atau lebih catatan.
Konsep dasar
Crossfilter didefinisikan di bawah namespace crossfilter. Ini menggunakan versi semantik. Pertimbangkan objek filter silang yang dimuat dengan kumpulan buah-buahan yang ditentukan di bawah ini -
var fruits = crossfilter ([
{ name: “Apple”, type: “fruit”, count: 20 },
{ name: “Orange”, type: "fruit”, count: 10 },
{ name: “Grapes”, type: “fruit”, count: 50 },
{ name: “Mango”, type: “fruit”, count: 40 }
]);
Jika kita perlu melakukan total record dalam sebuah grup, kita bisa menggunakan fungsi berikut -
var count = fruits.groupAll().reduceCount().value();
Jika kita ingin memfilter berdasarkan jenis tertentu -
var filtering = fruits.dimension(function(d) { return d.type; });
filtering.filter(“Grapes”)
Demikian pula, kita dapat melakukan pengelompokan dengan Crossfilter. Untuk melakukan ini, kita dapat menggunakan fungsi berikut -
var grouping = filtering.group().reduceCount();
var first = grouping.top(2);
Oleh karena itu, Crossfilter dibuat untuk menjadi sangat cepat. Jika Anda ingin menghitung ulang grup saat filter diterapkan, ini menghitung secara bertahap. Dimensi filter silang sangat mahal.
API Crossfilter
Mari kita telusuri Crossfilter API yang terkenal secara mendetail.
crossfilter([records])- Ini digunakan untuk membuat crossfilter baru. Jika catatan ditentukan, maka secara bersamaan menambahkan catatan yang ditentukan. Rekaman dapat berupa larik objek JavaScript atau primitif.
crossfilter.add(records) - Menambahkan record yang ditentukan ke crossfilter.
crossfilter.remove() - Menghapus semua record yang cocok dengan filter saat ini dari crossfilter.
crossfilter.size() - Mengembalikan jumlah record di crossfilter.
crossfilter.groupAll() - Ini adalah fungsi untuk mengelompokkan semua record dan menguranginya menjadi satu nilai.
crossfilter.dimension(value) - Ini digunakan untuk membangun dimensi baru menggunakan fungsi pengakses nilai yang ditentukan.
dimension.filter(value) - Ini digunakan untuk memfilter catatan untuk nilai kecocokan dimensi, dan mengembalikan dimensi.
dimension.filterRange(range) - Memfilter rekaman untuk nilai dimensi yang lebih besar dari atau sama dengan rentang [0], dan kurang dari rentang [1].
dimension.filterAll() - Menghapus filter apa pun pada dimensi ini.
dimension.top(k) - Ini digunakan untuk mengembalikan array baru yang berisi record k teratas, sesuai dengan urutan natural dari dimensi ini.
dimension.bottom(k) - Digunakan untuk mengembalikan array baru yang berisi record k terbawah, sesuai dengan urutan natural dari dimensi ini.
dimension.dispose() - Ini digunakan untuk menghilangkan dimensi dari crossfilter.
Pada bab selanjutnya, kita akan memahami secara singkat tentang D3.js.