Want more? Subscribe to my free newsletter:

The future of data-binding is Object.observe()

October 20, 2013

Object.observe() is a proposed mechanism for bringing true data-binding to the browser. It exposes a mechanism for observing changes to objects and arrays, notifying others of mutations made to these objects. In my JSConf talk on O.o() I walk developers through the API, discussing how it will change things for AngularJS, Ember and Polymer. Some of these libraries have already explored replacing their dirty-checking and set-traps with

Object.observe(). In fact, the Angular team reported last year that their bindings saw a 20-40x increase in speed when using an early version of it.

This is promising and the hope is once browser vendors other than Chrome implement the feature, many libraries using data-binding will see considerable performance boosts.

I plan on doing a more detailed write-up on Object.observe() in the near future, but until then you might be interested in the following resources: