DC.js - Jumlah Data

Hitungan data digunakan untuk menampilkan jumlah total catatan dalam kumpulan data. Ini melakukan dua jenis penghitungan berikut -

  • Total-count - jumlah total rekaman.

  • Filter-count - jumlah record yang cocok dengan filter saat ini.

Metode Penghitungan Data

Sebelum melanjutkan untuk menggunakan penghitungan data, kita harus memahami dc.dataCountkelas dan metodenya. Kelas dc.dataCount menggunakan mixin untuk mendapatkan fungsionalitas dasar dalam menampilkan hitungan data, yaitu -

  • dc.baseMixin

Dc.dataCount mendapatkan semua metode dari mixin ini dan memiliki metode sendiri untuk menampilkan jumlah data seperti yang dijelaskan di bawah -

formatNumber ([formatter])

Metode ini digunakan untuk mendapatkan atau mengatur format untuk jumlah filter dan jumlah total.

html ([opsi])

Ini digunakan untuk mendapatkan atau mengatur template HTML untuk menunjukkan jumlah item yang dipilih.

For example -

counter.html ({
   all: 'HTML template to use if all items are selected'
})

Di sini, 'semua' digunakan untuk memilih semua item menggunakan% total-count. Jika kita hanya ingin menggunakan beberapa item, maka kita dapat menggunakan beberapa record menggunakan opsi% filter-count.

Contoh penghitungan data

Mari kita lakukan penghitungan data di DC. Untuk melakukan ini, kita perlu mengikuti langkah-langkah yang diberikan di bawah ini -

Langkah 1: Tambahkan gaya

Mari kita tambahkan gaya di CSS menggunakan pengkodean yang diberikan di bawah ini -

.dc-chart { font-size: 12px; }

Di sini, kami telah menetapkan gaya untuk bagan.

Langkah 2: Buat variabel

Mari kita buat variabel di DC seperti yang ditunjukkan di bawah ini -

var barChart = dc.barChart('#line'); 
var countChart = dc.dataCount("#mystats");

Di sini, kami telah menetapkan id variabel barChart sejalan, sedangkan id countChart adalah mystats.

Langkah 3: Baca datanya

Baca data dari file people.csv seperti yang ditunjukkan di bawah ini -

d3.csv("data/people.csv", function(errors, people) {
   var mycrossfilter = crossfilter(people);
}

Jika data tidak ada, maka itu mengembalikan kesalahan. Sekarang, tetapkan data ke filter silang.

Di sini, kami menggunakan file people.csv, yang digunakan dalam contoh pembuatan bagan sebelumnya. Ini terlihat seperti yang ditunjukkan di bawah ini -

id,name,gender,DOB,MaritalStatus,CreditCardType
1,Damaris,Female,1973-02-18,false,visa-electron
2,Barbe,Female,1969-04-10,true,americanexpress
3,Belia,Female,1960-04-16,false,maestro
4,Leoline,Female,1995-01-19,true,bankcard
5,Valentine,Female,1992-04-16,false,
6,Rosanne,Female,1985-01-05,true,bankcard
7,Shalna,Female,1956-11-01,false,jcb
8,Mordy,Male,1990-03-27,true,china-unionpay

.........................................
........................................

Langkah 4: Atur dimensi

Anda dapat mengatur dimensi menggunakan pengkodean yang diberikan di bawah ini -

// age dimension
var ageDimension = mycrossfilter.dimension(function(data) { 
   return ~~((Date.now() - new Date(data.DOB)) / (31557600000)) 
});

Setelah dimensi ditentukan, kelompokkan usia menggunakan kode yang diberikan di bawah ini -

var ageGroup = ageDimension.group().reduceCount();

Langkah 5: Buat grafik

Sekarang, buat diagram batang menggunakan kode yang diberikan di bawah ini -

barChart
   .width(400)
   .height(200)
   .x(d3.scale.linear().domain([15,70]))
   .yAxisLabel("Count")
   .xAxisLabel("Age")
   .elasticY(true)
   .elasticX(true)
   .dimension(ageDimension)
   .group(ageGroup);

Sini,

  • Kami telah menetapkan lebar grafik 400 dan tinggi 200.
  • Selanjutnya, kami telah menentukan rentang domain sebagai [15,70].
  • Kami telah menetapkan label sumbu x sebagai usia dan label sumbu y sebagai hitungan.
  • Kami telah menetapkan fungsi elasticY dan X sebagai benar.

Langkah 6: Buat dan render bagan hitungan

Sekarang, buat dan render grafik hitungan menggunakan pengkodean di bawah ini -

countChart
   .dimension(mycrossfilter)
   .group(mycrossfilter.groupAll());

barChart.render();
countChart.render();

Di sini, kami telah menetapkan dimensi ke variabel crossfilter. Terakhir, kelompokkan semua catatan berdasarkan usia.

Langkah 7: Contoh kerja

Kode lengkapnya adalah sebagai berikut. Buat halaman webdatacount.html dan tambahkan perubahan berikut ke dalamnya.

<html>
   <head>
      <title>DC datacount sample</title>
      <link rel = "stylesheet" type = "text/css" href = "css/bootstrap.css" />
      <link rel = "stylesheet" type = "text/css" href = "css/dc.css" />
   
      <style>
         .dc-chart { font-size: 12px; }
      </style>

      <script src = "js/d3.js"></script>
      <script src = "js/crossfilter.js"></script>
      <script src = "js/dc.js"></script>
   </head>
   
   <body>
      <div>
         <div style = "width: 600px;">
            <div id = "mystats" class = "dc-data-count" style = "float: right">
               <span class = "filter-count"></span> selected out of <span
                  class = "total-count"></span> | <a href = "javascript:dc.filterAll();
                  dc.renderAll();">Reset All</a>
            </div>
         </div>

         <div style = "clear: both; padding-top: 20px;">
            <div>
               <div id = "line"></div>
            </div>
         </div>
      </div>

      <script language = "javascript">
         var barChart = dc.barChart('#line'); // , 'myChartGroup');
         var countChart = dc.dataCount("#mystats");

         d3.csv("data/people.csv", function(errors, people) {
            var mycrossfilter = crossfilter(people);

            // age dimension
            var ageDimension = mycrossfilter.dimension(function(data) { 
               return ~~((Date.now() - new Date(data.DOB)) / (31557600000)) 
            });
            var ageGroup = ageDimension.group().reduceCount();

            barChart
               .width(400)
               .height(200)
               .x(d3.scale.linear().domain([15,70]))
               .yAxisLabel("Count")
               .xAxisLabel("Age")
               .elasticY(true)
               .elasticX(true)
               .dimension(ageDimension)
               .group(ageGroup);

            countChart
               .dimension(mycrossfilter)
               .group(mycrossfilter.groupAll());

            barChart.render();
            countChart.render();
         });
      </script>
   </body>
</html>

Sekarang, minta browser dan kita akan melihat respons berikut.

Halaman awal penghitungan data ditunjukkan di bawah ini.

Setelah memilih usia tertentu, itu menunjukkan hitungan seperti yang ditunjukkan pada gambar di bawah.