GUNMA GIS GEEK

群馬県の片隅でオープンデータとデータビジュアライゼーションとGIS(地理情報システム)に戯れるエンジニアのブログ。

*

【D3.js】proxyを使ってデータセットが変更されたらチャートを再描画する。

     - D3v4, Javascript

はてなブックマーク - 【D3.js】proxyを使ってデータセットが変更されたらチャートを再描画する。
Pocket

D3.jsを使ってデータビジュアライゼーションを作成するときにありがちな処理として、入力フォームの値が変更されたらチャートを再描画するというのがあります。
入力フォームのchangeイベントが発火されたらフォームの値を取得してredrawするわけですが、入力項目の数が増えてきたりすると管理が面倒になってきます。
できることなら、入力フォームのイベントとチャートの描画は疎結合にして、データセットが変更されたらチャートを描画するような処理にしたいところです。
ECMAScript 2015にて実装されたproxy機能を使うとオブジェクトの変更を簡単に監視することができます。

※ Proxy Objectは2016/9/6現在、一部のブラウザでしか使用することができません。

Can I use Proxy Object

Can I use… Support tables for HTML5, CSS3, etc

簡単な使い方

詳細なproxyオブジェクトの機能については、MDNを参照していただくとして、最も単純なgeter,seterの監視処理を試してみます。

上記のコードは、dataオブジェクトに対してgeter,seterのトラップを定義したハンドラを束縛し、proxyオブジェクトを生成しています。
実際にブラウザのJavaScriptコンソール上でproxyオブジェクトを操作した結果が以下です。

proxy2016-09-06 10-20-19

proxyオブジェクトに新たなプロパティを設定するとdataオブジェクトにその内容が反映されているのが見て取れます。
同時にハンドラ内に記述されたconsole.logが実行されています。
proxyオブジェクトを使用することでオブジェクトに簡単にobserveを仕込むことができました。

D3サンプル

proxyハンドラ内にチャートを再描画する処理を挟み込み、データセットに変更があったらチャートを再描画するサンプルです。

D3 - use Proxy

bl.ocks – D3 use Proxy

はてなブックマーク - 【D3.js】proxyを使ってデータセットが変更されたらチャートを再描画する。
Pocket

 - D3v4, Javascript

  関連記事

no image
配列とarguments

引き続き「テスト駆動JavaScript」本を読んで勉強しているのですが、ちょっ …

mobileapi
iphoneに搭載されているセンサー(GPS位置情報、ジャイロセンサー、電子コンパス、加速度センサー)の情報を取得

現時点における、モバイルデバイスの各センサーから情報を取得する方法を確認してみま …

no image
documentオブジェクトの拡張

昨日、めちゃくちゃなコードを作っていて知った副産物 documentオブジェクト …

autocomplete.kana.js
[Autocomplete] かな入力で名前(漢字)を絞り込むセレクトボックス

example 入力した「ひらがな」を元に名前(漢字)の一覧を絞り込むセレクトボ …

natural-selection-2
エンジニアが正しく「I love you」と伝えるための遺伝的アルゴリズム(殺伐)

「エンジニアが正しく「好き」と伝えるための実装法」という記事が話題だったので、乗 …

gunmaweb14
Gunma.web #14で発表したスライド「canvasで遊ぼう!」

遅くなりましたがGunma.web #14で発表したスライドです。 「canva …

javascriptTheGoodParts
JavaScriptのWith文を使っちゃいけない訳

「JavaScript: The Good Parts」の中で「With文使うん …

Core HTML5 Canvas: Graphics, Animation, and Game Development
【英語】Kindleで買えるお勧めHTML5 Canvas技術書【読めない】

Kindleでは海外の技術書が手軽に買えてありがたいですね。 最近買った本の中か …

JavaScripNinja
JavaScript Ninjaは全てのフロントエンドエンジニアが一度は読んでおくべき本

JavaScript Ninjaの極意 ライブラリ開発のための知識とコーディング …

test000006
「SVG Crowbar」表示されているインラインSVG要素を抜き出してSVGファイルとして保存するブックマークレット

SVG Crowbar HTMLドキュメントの中に埋め込まれているSVG要素を抜 …