A Room with a
About Me
Matt Stow
@stowball
Lead UX Engineer at
National Rugby League
2006
data:image/s3,"s3://crabby-images/776a9/776a90fd715bf3cf0bcfac52df9e7115aa5cf8cb" alt=""
data:image/s3,"s3://crabby-images/9ab17/9ab1773e420b4f00c6e42e94d5ccc6858d4ee6d6" alt=""
2010
data:image/s3,"s3://crabby-images/c77de/c77de72c07225bbd7eafe8bbc8f489bc3ff96b6c" alt=""
data:image/s3,"s3://crabby-images/39a98/39a984880a6e62a1a8901cf70a93838a2cd7f70c" alt=""
2013
2014
2015
SSR
2016
data:image/s3,"s3://crabby-images/07a6a/07a6ae96f44470067589b61df0aab7acefcb7bfe" alt=""
Rebuilding the NRL
Constraints
- Enterprise CMS
- .NET back-end
- Primarily a content platform
- A number of complex and dynamic UIs
- Really short timeframes
React Habitat
You should use React Habitat any time there is a framework or CMS rendering your HTML and you
want one or multiple React components on the page
This framework is perfect for that
data:image/s3,"s3://crabby-images/e6608/e66084165445cf97018322c40e509fa178d6597d" alt=""
data:image/s3,"s3://crabby-images/0de61/0de612e24f01f0410b8b5b39fb28b357ad6ac808" alt=""
data:image/s3,"s3://crabby-images/d4cb0/d4cb0772d6103b63687ee920108937b19c24c18d" alt=""
Pros
- React is good at building interactive UI
- Components can easily be inserted in the DOM
- Stringified JSON can be passed as props; reducing the need to fetch initial data
Cons
- Double-divving
- Components can't cross-communicate without
a pub/sub mechanism or Redux 😔
- Need to add interactivity to existing HTML?
Recreate every HTML component in JS 😩
- JS bundle keeps getting bigger & parse times longer 😫
- Before JS is initialised, there is no content 😱
data:image/s3,"s3://crabby-images/7343c/7343c52e1f934031f11f56041e47c29a80b64b9b" alt=""
data:image/s3,"s3://crabby-images/74e82/74e826e70e887b52c2adc483a0c919fb61178d60" alt=""
Hello, Glandular Fever
data:image/s3,"s3://crabby-images/e0f08/e0f082cb1ad30d9c308483a6ac552ae2b58680de" alt=""
Hello, Quench Vue
Simple, client-side hydration of pre-rendered Vue.js apps
Pros
- Vue is really good at building interactive UI
- Multiple apps can easily be inserted in the DOM
- Stringified JSON can be passed as initial data
-
Apps can easily cross-communicate via an event bus
-
Fewer templates need to be maintained in JS, resulting in a smaller & faster bundle
- Allows for server-side rendering without Node.js
Cons
- What started as a 411b library has
ballooned to 1.1kb minified & gzipped 😎
- There‘s no ideal way of documenting our applications‘ data structures
- We duplicate some of our template markup in
Handlebars & Razor templates
- We have to manage our other templates in JS string literals, but we‘re hoping to change that
(Atom actually makes it not too painful though)
Vue 101
data:image/s3,"s3://crabby-images/0b34f/0b34fc3f4e2157813bf5748008d0c8c0c34e34b8" alt=""
data:image/s3,"s3://crabby-images/246ee/246eef7d1e43eb78706c37bda693765cfdbce48c" alt=""
Using Quench
- Output your default data within a [q-data] attribute
- Bind data properties to DOM nodes with [v-text]
- Hide elements from the compiler with <!-- <q> -->
- Convert the [q-data] with createAppData()
- Create the template with createAppTemplate()
How does it work?
data:image/s3,"s3://crabby-images/0f757/0f757d8c8229e03fe12f24954645fc4cb57e5f92" alt=""
data:image/s3,"s3://crabby-images/80b2d/80b2dbaf089af80c1435de843f7d63d5e6109d53" alt=""
data:image/s3,"s3://crabby-images/cd61a/cd61a3ded74597ffea06f28d64f79179722e48c0" alt=""
data:image/s3,"s3://crabby-images/1f266/1f266eb9717fae801e2485c91d736a775c3bb002" alt=""
data:image/s3,"s3://crabby-images/8cc30/8cc3004e9ecf51d36d34341f3e4daad17022329d" alt=""
data:image/s3,"s3://crabby-images/7343c/7343c52e1f934031f11f56041e47c29a80b64b9b" alt=""
data:image/s3,"s3://crabby-images/74e82/74e826e70e887b52c2adc483a0c919fb61178d60" alt=""
data:image/s3,"s3://crabby-images/0743c/0743c6691a56405a8e96a8c85b6b1459094b2de5" alt=""
The News page uses 4 unique Vue apps
Multiple apps? Huh?!
- We‘re not an SPA, so we don‘t need to manage the entire application‘s state from one single source
- Unlike React, Vue has a clear distinction between what‘s an app and what‘s a component
- Each app is restricted in its scope. It only has the exact template and data that it needs
- Each page of the website can be completely different
- Our resilience to failure is much greater with everything independent
data:image/s3,"s3://crabby-images/1b527/1b52782f4d2655ef4a996dfdd5bb61f4990b1b21" alt=""
data:image/s3,"s3://crabby-images/84d40/84d40e54e1b5dd85caa2821bcfb74e6c3f007876" alt=""
data:image/s3,"s3://crabby-images/279b4/279b461aead5f3389036544cd793af7785f724bd" alt=""
data:image/s3,"s3://crabby-images/2656e/2656e97c34fb0857ac9839537e8dff7022bdfae2" alt=""
data:image/s3,"s3://crabby-images/a90af/a90af2daf6f9499392261edc42f6e130684952f7" alt=""
data:image/s3,"s3://crabby-images/b5214/b5214d8c2693f3e5b6bb527cfec9095cf8a123e2" alt=""
data:image/s3,"s3://crabby-images/32a40/32a4033e03d40fcff5eacbda5b7e39973118ad4b" alt=""
data:image/s3,"s3://crabby-images/3f2ec/3f2ec8e8d47a172c8b91e061da06295492a0e676" alt=""
data:image/s3,"s3://crabby-images/f781e/f781effa7b97fd1e1fd2b6fb29859220ffd2e916" alt=""
data:image/s3,"s3://crabby-images/72340/72340e14df9e68fad8565b1f36d0a470e3ddd3a2" alt=""
- All aspects of performance has improved:
file size, TTFMP, TTFI, reflow etc
- Developer experience is really good:
simpler to learn, code & reason about
- We can test live data really easily in dev
- User experience is even better!
Our verdict
data:image/s3,"s3://crabby-images/e6cbd/e6cbdc7d8fffe53807bb58a7cf7c004b4f0fcb04" alt=""
data:image/s3,"s3://crabby-images/6a73e/6a73efecb93c6aa97988ba2a005f69698ad51441" alt=""
with a
Thank you!
@stowball
A Room with a Vue
By Matt Stow
A Room with a Vue
How the NRL uses Vue.js and Quench Vue to progressively enhance and hydrate server-side rendered HTML
- 3,623