D3 7.0
180 points by cltsang 4 years ago | 61 comments- whimsicalism 4 years agoThe one critique I have of D3 is that it is becoming increasingly closely paired with Observable, such that when I'm searching for examples of how to make something in d3, I can only find Observable examples that require the Observable runtime in order to function properly.
I think the examples should have a JS native version in addition to the Observable implementation.
- DataCrayon 4 years agoThat's part of the reason I started my book "Visualisation with D3.js"[1]... it's early access and I'm trying to find more time to work on it, but it's all JS native
[1] https://datacrayon.com/shop/product/visualisation-with-d3/
- _dwt 4 years agoIt's a real pain. I work with lots of "data science" types who are often trying to concurrently learn JavaScript and d3 - often with JS as their first or second programming language. It's difficult enough for an experienced programmer coming back to d3 after a few versions to pick out what's d3 vs. what's Observable - and very difficult to help a relative newbie through the process of turning what's shown in an Observable notebook into something that can run in an ordinary web page.
- vmception 4 years agoEven more difficult to deal with that and conforming it to Vue/React SPAs
- vmception 4 years ago
- kowlo 4 years agoIndeed - I don't like the pairing with Observable. I don't like Observable in general because the full experience can't be self-hosted. However, both projects belong to Mike, and D3.js is free - so I can't complain.
- norswap 4 years agoDidn't they have an export function that allowed self-hosting something you developped on Observable? (Or is it the development part that you want to self-host for "full experience"?)
- jacobolus 4 years agoYou can self-host the runtime, and use code from notebook cells in whatever context you like. The closed part is the “notebook chrome” (editor, history view, social features, etc.).
- 4 years ago
- jacobolus 4 years ago
- norswap 4 years ago
- dimal 4 years agoWhat’s the difference between the two? As someone who only dips into D3 every few years and just discovered Observable, I wasn’t aware that they were different. I thought Observable was just a way of sharing D3 visualizations.
- j-pb 4 years agoObservable is like Jupyter for Javascript. A general JS notebook environment, with the added twist that it uses reactive dataflow ideas to evaluate cells in a "right" and deterministic order (a common footgun in Jupyter where cells might be reevaluated manually, resulting in unexpected state).
D3 is a JS library for data visualisations.
Both are the brainchild of Mike Bostock. That's the connection. :)
- tracyhenry 4 years ago
- j-pb 4 years ago
- th0ma5 4 years agoSomeone should make an open source version of the Observable ecosystem or integrate it into Jupyter tooling better. The notebook format is not encrypted or anything.
- protoduction 4 years agoI posted this on HN a little while back [1], it's an open source alternative editor/runtime for Observable as a plugin for Starboard.
- th0ma5 4 years agoNice!!
- th0ma5 4 years ago
- protoduction 4 years ago
- j-pb 4 years agoThat's a bit like complaining that there are examples on codepen.
I'm super grateful that they provide such good documentation, which is second to none, in a nicely explorable environment.
- whimsicalism 4 years agoThe difference is that examples in Codepen are easily reproducable in another environment.
d3, on the other hand, has converted most of their examples to Observable, which requires extensive research to convert back to JS (in the best case) and in the worst case requires reverse engineering the runtime.
I'm not the only one with this opinion, there are plenty of others who have struggled through similar issues and discussed it.
"The process of converting an Observable notebook to standalone html and/or js is clearly not as simple and copying and pasting. The use of Observable notebooks for all D3 examples has made the introduction to the library much more challenging for this reason." [0]
[0] https://stackoverflow.com/questions/53155957/convert-d3-obse...
[1]: https://talk.observablehq.com/t/i-want-to-learn-d3-i-don-t-w...
- j-pb 4 years agoI work with both D3 and Observable full time.
The claim that one has to "reverse engineer the runtime" is simply absurd.
The people that complain about D3 on observable always turn out to have taken neither the time to understand Observable nor D3 and are looking for a way to just copy paste something into their codebase, without understanding it, and without any willingness to really learn the tools they are using. Which would have never worked in the first place, because D3 is not a plotting library like vega or observables plot, it's a library library, building material from which you can build your own bespoke visualisations.
Observable is in essence reevaluating the entire code with each "requestAnimationFrame", no fancy diffing a la react or other magic, if it runs in observable, it will also run in your code as a static thing. Copy paste the cells out of observable, prepend them with a "const" and you're done, not more work than removing and rewriting the boilerplate that's in every codepen.
- macNchz 4 years agoYeah I encountered this problem recently as someone who was once reasonably familiar with d3 and came back to it after several years away.
I find myself wanting to start with a working example I can riff off of more in d3 than with many other tools I've used, so I totally understand the appeal of interactive examples in Observable but find it super frustrating and cumbersome when it comes to actually rolling what I'm working on into an existing application.
- j-pb 4 years ago
- whimsicalism 4 years ago
- DataCrayon 4 years ago
- spankalee 4 years ago> Adopt type: module. #3501
Standard JS modules, very nice! D3 now works in all playgrounds and libraries even as dependencies without non-standard tooling!
https://jsbin.com/ducosajehi/edit?html,output
I do wish they didn't even publish UMD, that's a recipe for duplication if some libraries import the module and some import the UMD.
- azangru 4 years agoSo, is d3 tree-shakeable yet? If I import { scaleLinear } from 'd3' in a webpack-built project, will I get only the scaleLinear code? As far as I remember, in v6 this will import a lot of (or perhaps the rest of) d3 as well.
- jwilber 4 years agoYou can also just import it from d3-scale.
- azangru 4 years agoYeah, I know.
I am probably being unreasonable; but it's kind of nice to be able to have a single third-party dependency out of which you can pick what you need at the moment, rather than a host of small third-party dependencies. Kind of like lodash, from which you can at least import individual functions (import merge from 'lodash/merge') rather than installing all those functions as individual packages.
- jwilber 4 years agoI agree with you and wish that were an option, but I do think most build tools will tree shake for you nowadays.
- jwilber 4 years ago
- azangru 4 years ago
- jwilber 4 years ago
- mirekrusin 4 years agoExciting to see ESM everywhere. It works so well with Observable. I'm trying to put live playgrounds at observable for my packages as part of docs [0] - just starting, nothing exciting to see there yet, but I think the concept of playground as part of docs is quite awesome.
- DataCrayon 4 years agoGreat! Nice to see very few breaking changes, the Dreamcast intro animation still works https://datacrayon.com/posts/visualisation/visualisation-wit...
- terpimost 4 years agoThank you Mike!
- nickreese 4 years agoThis x1000. D3 is such a great tool. Just the scales/coloring/map project libraries would be impressive standalone. D3 is incredible.
- nickreese 4 years ago
- Vaslo 4 years agoUsed this in a data viz class and I’d say it’s overkill for most visualizations. Also very difficult to learn and frustrating to implement with all the “enter, exit” stuff. Excel, Tableau, etc so much easier and most of what you need to do visualizations in the corporate setting. Obviously it’s excellent for very specialized unusual visualizations but it’s rare those are really needed.
- mskullcap 4 years agoAll the "enter, exit" stuff is what makes d3 beautiful. From a core handful of ideas, Mike is able to express a vast world of visualizations. I think it is the most amazing framework I have had the pleasure of using in my 30+yrs of software development. Ya, you could grab bar chart library and just give it data and get a graph out, or, you could spend a little time with d3 and actually learn something so powerful you can make bar charts - or virtually any other kind of visualization you will ever need. Well worth working past the frustration, imo.
- drewda 4 years agoIf you want the polish of d3 and some of its power without all the complexity, try Vega Lite and related tooling: https://vega.github.io/vega-lite/
- HatchedLake721 4 years agoApples and oranges.
D3 is a low level visualisation library where you write code.
Excel/Tableau are business tools.
- javierluraschi 4 years agoWhy can't we have both? -- I had a similar frustration and got to work on https://hal9.ai, you get prebuilt blocks to easily import/transform/visualize data, while also being able modify the D3/Plot sources to your hearts contempt.
- javierluraschi 4 years ago
- th0ma5 4 years agoYou actually don't have to use enter and exit and I agree it is cumbersome and unnecessary although I understand the desire for inband and out of band separation... https://medium.com/d3js-tutorials/d3-without-enter-91934575d...
- gaws 4 years ago> Excel, Tableau, etc so much easier and most of what you need to do visualizations in the corporate setting.
D3 is the best way to make visualizations online. Yes, it requires learning the library and building things from scratch, but it's light years better than the dog shit modules Tableau offers.
- NelsonMinar 4 years agoYou're comparing Paint to Photoshop.
- mskullcap 4 years ago
- 4 years ago
- kowlo 4 years agoFeels like less than a year ago that we had D3 v6!
- dang 4 years agoD3 6.0 - https://news.ycombinator.com/item?id=24288497 - Aug 2020 (86 comments)
- wongarsu 4 years agoD3 v6 was released on 27th Aug 2020, so your feeling is right. We seem to get a major release about every year now, compared to every two years before v5.
- dang 4 years ago