René Schimmelpfennig
17. März 2016
data:image/s3,"s3://crabby-images/bc902/bc902c6739311cd627dedf54c69a6b729afb4f51" alt=""
agenda
- React
- example
- deployment
- testing
- questions
React
data:image/s3,"s3://crabby-images/81d8d/81d8db29df65d2da50942bf07a883283b2d65380" alt=""
- created 2011 by Jordan Walke
- open source
- isn't an MVC framework
- it's a library
- for data rendering
- efficient updating mechanism
- components as custom HTML tags
- clean separation between components
data:image/s3,"s3://crabby-images/5856b/5856bc8a74215535f0e23e79f0dd3f0da9cacf17" alt=""
features
- reusable components
- Isomorphic JavaScript (client-side + server-side)
- virtual DOM
- very fast
- don't use templates (instead: pure JS)
- React native (Android + iOS Apps)
users
data:image/s3,"s3://crabby-images/acb73/acb73011686ffbd585544f4314df559fb2e08be0" alt=""
data:image/s3,"s3://crabby-images/ba87f/ba87fc3e37f30b122843feab551b0267e20834b5" alt=""
data:image/s3,"s3://crabby-images/6d92c/6d92c886e684d8ce952462b83c78cf89b343dd2c" alt=""
http://libscore.com/
https://github.com/facebook/react/wiki/Sites-Using-React/
data:image/s3,"s3://crabby-images/5856b/5856bc8a74215535f0e23e79f0dd3f0da9cacf17" alt=""
data:image/s3,"s3://crabby-images/81d8d/81d8db29df65d2da50942bf07a883283b2d65380" alt=""
JSX
- JavaScript extension syntax
- allowing easy quoting of HTML
- processed into JavaScript calls
data:image/s3,"s3://crabby-images/567eb/567eba6a08e99d6bcc7ada11455e8da4bada5a83" alt=""
data:image/s3,"s3://crabby-images/b38e7/b38e7161396e04cfeec1e8d3af580b67b91cc143" alt=""
components
data:image/s3,"s3://crabby-images/d1fa4/d1fa4ab1a88e8b5e7ec466f28ed35171e8011311" alt=""
properties
- passed to a component
- immutable
- "properties flow down and actions flow up"
- integrated validation
states
- mutable
- private to the component
- can be changed by calling this.setState()
- change => re-render of component
example
nodefilestore
data:image/s3,"s3://crabby-images/55685/556852afe2cb1d26e45438f25f28ee2838911b89" alt=""
https://github.com/MCeddy/nodefilestore
- instant filesharing
- nodejs project
- open source (MIT)
- frontend + backend => ES6
- store files in MongoDB (GridFS)
demo
deployment
data:image/s3,"s3://crabby-images/68a15/68a15cfcc0ed3911223e46b5c4015784fa6ee3ac" alt=""
- bundler for all assets
- gulp/grunt not required
- script tasks in package.json
- watcher: express middleware
data:image/s3,"s3://crabby-images/1badc/1badc81667b06e742572ad1d3edf596bb32836e4" alt=""
demo
testing
data:image/s3,"s3://crabby-images/8b231/8b231983cec2f28c42f9e5c91ed3f804af8a1cb7" alt=""
Sinon.JS
Chai.JS
Shallow Rendering
enzyme
demo
questions
data:image/s3,"s3://crabby-images/50d45/50d45d5df78f35107b4b3f2020909737dc67b9d0" alt=""
@scr_at
https://slides.com/scr_at/react
data:image/s3,"s3://crabby-images/55685/556852afe2cb1d26e45438f25f28ee2838911b89" alt=""
https://github.com/MCeddy/nodefilestore