Browse Source

Merge branch '0.12-stable'

main
Paul O’Shannessy 10 years ago
parent
commit
2a0b379a9d
  1. 4
      Rakefile
  2. 71
      _data/acknowledgements.yml
  3. 6
      _data/nav_docs.yml
  4. 20
      _js/examples/hello.js
  5. 66
      _js/examples/markdown.js
  6. 48
      _js/examples/timer.js
  7. 77
      _js/examples/todo.js
  8. 2
      _js/html-jsx.js
  9. 4
      _js/jsx-compiler.js
  10. 4
      _js/live_editor.js
  11. 2
      _posts/2014-10-16-react-v0.12-rc1.md
  12. 127
      _posts/2014-10-28-react-v0.12.md
  13. 44
      docs/02-displaying-data.md
  14. 2
      docs/02-displaying-data.zh-CN.md
  15. 145
      docs/02.1-jsx-in-depth.md
  16. 71
      docs/02.2-jsx-spread.md
  17. 2
      docs/02.3-jsx-gotchas.md
  18. 2
      docs/05-reusable-components.md
  19. 159
      docs/06-transferring-props.md
  20. 2
      docs/07-forms.md
  21. 0
      docs/08-working-with-the-browser.md
  22. 0
      docs/08.1-more-about-refs.md
  23. 0
      docs/09-tooling-integration.md
  24. 0
      docs/10-addons.md
  25. 10
      docs/10.1-animation.md
  26. 0
      docs/10.2-form-input-binding-sugar.md
  27. 0
      docs/10.3-class-name-manipulation.md
  28. 6
      docs/10.4-test-utils.md
  29. 0
      docs/10.5-clone-with-props.md
  30. 0
      docs/10.6-update.md
  31. 0
      docs/10.7-pure-render-mixin.md
  32. 0
      docs/10.8-perf.md
  33. 2
      docs/getting-started.md
  34. 2
      docs/getting-started.zh-CN.md
  35. 22
      docs/ref-01-top-level-api.md
  36. 27
      docs/ref-02-component-api.md
  37. 16
      docs/ref-04-tags-and-attributes.md
  38. 1
      docs/ref-08-reconciliation.md
  39. 192
      docs/ref-09-glossary.md
  40. 6
      docs/tutorial.md
  41. 4
      tips/03-if-else-in-JSX.md
  42. 6
      tips/16-references-to-components.md

4
Rakefile

@ -4,12 +4,12 @@ require('yaml')
desc "generate js from jsx" desc "generate js from jsx"
task :js do task :js do
system "../bin/jsx _js js" system "../bin/jsx --harmony _js js"
end end
desc "watch js" desc "watch js"
task :watch do task :watch do
Process.spawn "../bin/jsx --watch _js js" Process.spawn "../bin/jsx --watch --harmony _js js"
Process.waitall Process.waitall
end end

71
_data/acknowledgements.yml

@ -1,22 +1,30 @@
--- ---
- - Adam Krebs - - Adam Krebs
- Adam Mark
- Adam Solove - Adam Solove
- Alan deLevie - Alan deLevie
- Alex Zelenskiy - Alex Zelenskiy
- Alexander Solovyov - Alexander Solovyov
- Alexey Raspopov
- Andre Z Sanchez
- Andreas Svensson - Andreas Svensson
- Andres Suarez
- Andrew Davey - Andrew Davey
- Andrew Rasmussen
- Andrew Zich - Andrew Zich
- Andrey Popp - Andrey Popp
- Anthony van der Hoorn - Anthony van der Hoorn
- Areeb Malik
- Ayman Osman - Ayman Osman
- Ben Alpert - Ben Alpert
- Ben Foxall
- Ben Newman - Ben Newman
- Ben Ripkens - Ben Ripkens
- Bill Fisher - Bill Fisher
- Bob Eagan - Bob Eagan
- Bojan Mihelac - Bojan Mihelac
- Brandon Bloom - Brandon Bloom
- Brandon Tilley
- Brian Cooke - Brian Cooke
- Brian Kim - Brian Kim
- Brian Reavis - Brian Reavis
@ -24,12 +32,17 @@
- Cam Spiers - Cam Spiers
- Cassus Adam Banko - Cassus Adam Banko
- Cat Chen - Cat Chen
- Charles Marsh
- Cheng Lou - Cheng Lou
- Chris Sciolla
- Christian Alfoni
- Christian Roman - Christian Roman
- Christoph Pojer - Christoph Pojer
- Christopher Monsanto - Christopher Monsanto
- Clay Allsopp - Clay Allsopp
- Connor McSheffrey - Connor McSheffrey
- Cotton Hou
- Dan Abramov
- Dan Schafer - Dan Schafer
- Daniel Gasienica - Daniel Gasienica
- Daniel Lo Nigro - Daniel Lo Nigro
@ -40,6 +53,7 @@
- David Hellsing - David Hellsing
- David Hu - David Hu
- Devon Blandin - Devon Blandin
- Dmitrii Abramov
- Dmitry Mazuro - Dmitry Mazuro
- Dustin Getz - Dustin Getz
- Enguerran - Enguerran
@ -49,21 +63,24 @@
- Evan Coonrod - Evan Coonrod
- Fabio M. Costa - Fabio M. Costa
- Felipe Oliveira Carvalho - Felipe Oliveira Carvalho
- Felix Gnass
- Felix Kling - Felix Kling
- Fernando Correia - Fernando Correia
- François-Xavier Bois - François-Xavier Bois
- Fred Zhao - Fred Zhao
- G Scott Olson - G Scott Olson
- Garren Smith
- Geert Pasteels - Geert Pasteels
- Geert-Jan Brits - Geert-Jan Brits
- George A Sisco III - George A Sisco III
- Gilbert - Gilbert
- Glen Mailer
- Greg Hurrell - Greg Hurrell
- - Greg Roodt - Greg Roodt
- Guangqiang Dong - Guangqiang Dong
- Guido Bouman - Guido Bouman
- Harry Hull - Harry Hull
- Harshad Sabne - - Harshad Sabne
- Hendrik Swanepoel - Hendrik Swanepoel
- Hugo Jobling - Hugo Jobling
- Ian Obermiller - Ian Obermiller
@ -71,25 +88,36 @@
- Irae Carvalho - Irae Carvalho
- Isaac Salier-Hellendag - Isaac Salier-Hellendag
- Ivan Kozik - Ivan Kozik
- Ivan Vergiliev
- Jacob Gable
- Jacob Greenleaf
- Jaime Mingo - Jaime Mingo
- Jakub Malinowski - Jakub Malinowski
- James Brantly - James Brantly
- James Ide - James Ide
- James Seppi
- Jamie Wong - Jamie Wong
- Jamison Dance - Jamison Dance
- Jan Hancic
- Jan Kassens - Jan Kassens
- Jared Forsyth - Jared Forsyth
- Jason Bonta - Jason Bonta
- Jason Trill - Jason Trill
- Jean Lauliac - Jean Lauliac
- Jed Watson
- Jeff Barczewski - Jeff Barczewski
- Jeff Carpenter - Jeff Carpenter
- Jeff Chan
- Jeff Morrison - Jeff Morrison
- Jeff Welch - Jeff Welch
- Jeffrey Lin - Jeffrey Lin
- Jesse Skinner
- Jignesh Kakadiya - Jignesh Kakadiya
- Jim OBrien
- Jimmy Jea
- Jing Chen - Jing Chen
- Johannes Baiter - Johannes Baiter
- Johannes Emerich
- John Watson - John Watson
- Jon Beebe - Jon Beebe
- Jonas Enlund - Jonas Enlund
@ -101,15 +129,18 @@
- Josh Yudaken - Josh Yudaken
- Joshua Ma - Joshua Ma
- Julen Ruiz Aizpuru - Julen Ruiz Aizpuru
- Julien Bordellier
- Jun Wu - Jun Wu
- Juraj Dudak - Juraj Dudak
- Justin Jaffray - Justin Jaffray
- Karl Mikkelsen - Karl Mikkelsen
- Karpich Dmitry
- Keito Uchiyama - Keito Uchiyama
- Kit Randel - Kit Randel
- Kunal Mehta - Kunal Mehta
- Kyle Mathews - Kyle Mathews
- Laurence Rowe - Laurence Rowe
- Lee Byron
- Levi McCallum - Levi McCallum
- Lily - Lily
- Logan Allen - Logan Allen
@ -117,23 +148,40 @@
- Marcin Kwiatkowski - Marcin Kwiatkowski
- Marcin Szczepanski - Marcin Szczepanski
- Mariano Desanze - Mariano Desanze
- Mark Anderson
- Mark Hintz
- Mark IJbema
- Mark Richardson - Mark Richardson
- Marshall Roch - Marshall Roch
- - Martin Andert - Martin Andert
- Martin Konicek - Martin Konicek
- Mathieu M-Gosselin - Mathieu M-Gosselin
- Matt Harrison - Matt Harrison
- Matthew Dapena-Tretter - Matthew Dapena-Tretter
- Matti Nelimarkka - Matti Nelimarkka
- Max F. Albrecht
- Michael Chan
- - Michael Randers-Pehrson
- Michal Srb - Michal Srb
- Mike D Pilsbury
- Miorel Palii
- Mouad Debbar - Mouad Debbar
- Nadeesha Cabral - Nadeesha Cabral
- Naman Goel
- Nate Hunzaker - Nate Hunzaker
- Nathan White
- Nicholas Bergson-Shilcock - Nicholas Bergson-Shilcock
- Nick Fitzgerald
- Nick Gavalas - Nick Gavalas
- Nick Merwin
- Nick Thompson - Nick Thompson
- Nick Williams
- Niklas Boström - Niklas Boström
- Oleg
- Oleksii Markhovskyi
- Oliver Zeigermann
- Owen Coutts - Owen Coutts
- Pablo Lacerda de Miranda
- Pascal Hartig - Pascal Hartig
- Paul O’Shannessy - Paul O’Shannessy
- Paul Seiffert - Paul Seiffert
@ -148,32 +196,49 @@
- Richard D. Worth - Richard D. Worth
- Richard Feldman - Richard Feldman
- Richard Livesey - Richard Livesey
- Rick Beerendonk
- Rob Arnold
- Ryan Seddon - Ryan Seddon
- Sahat Yalkabov - Sahat Yalkabov
- Sam Selikoff
- Sander Spies - Sander Spies
- Sean Kinsey - Sean Kinsey
- Sebastian Markbåge - Sebastian Markbåge
- Sergey Generalov
- Shane O'Sullivan
- Shaun Trennery - Shaun Trennery
- Sheraz
- Shripad K
- Simon Højberg - Simon Højberg
- Simon Welsh
- Stefan Dombrowski - Stefan Dombrowski
- Stephen Murphy - Stephen Murphy
- Stoyan Stefanov - Stoyan Stefanov
- Sundeep Malladi - Sundeep Malladi
- Sunny Juneja
- Sven Helmberger - Sven Helmberger
- Sébastien Lorber
- Thomas Aylott - Thomas Aylott
- Thomas Boyt - Thomas Boyt
- Thomas Shaddox - Thomas Shaddox
- Thomas Shafer - Thomas Shafer
- ThomasCrvsr
- Timothy Yung - Timothy Yung
- Tom Haggie - Tom Haggie
- Tom Hauburger
- Tom MacWright
- Tom Occhino - Tom Occhino
- Ville Immonen - Ville Immonen
- Vjeux - Vjeux
- Volkan Unsal - Volkan Unsal
- Wayne Larsen - Wayne Larsen
- WickyNilliams
- Wincent Colaiuta - Wincent Colaiuta
- XuefengWu
- Yuriy Dybskiy - Yuriy Dybskiy
- Yuval Dekel - Yuval Dekel
- Zach Bruggeman - Zach Bruggeman
- cutbko
- davidxi - davidxi
- imagentleman - imagentleman
- jon madison

6
_data/nav_docs.yml

@ -23,6 +23,8 @@
subitems: subitems:
- id: jsx-in-depth - id: jsx-in-depth
title: JSX in Depth title: JSX in Depth
- id: jsx-spread
title: JSX Spread Attributes
- id: jsx-gotchas - id: jsx-gotchas
title: JSX Gotchas title: JSX Gotchas
- id: interactivity-and-dynamic-uis - id: interactivity-and-dynamic-uis
@ -31,6 +33,8 @@
title: Multiple Components title: Multiple Components
- id: reusable-components - id: reusable-components
title: Reusable Components title: Reusable Components
- id: transferring-props
title: Transferring Props
- id: forms - id: forms
title: Forms title: Forms
- id: working-with-the-browser - id: working-with-the-browser
@ -77,6 +81,8 @@
title: Special Non-DOM Attributes title: Special Non-DOM Attributes
- id: reconciliation - id: reconciliation
title: Reconciliation title: Reconciliation
- id: glossary
title: React (Virtual) DOM Terminology
- title: Flux - title: Flux
items: items:
- id: flux-overview - id: flux-overview

20
_js/examples/hello.js

@ -1,14 +1,14 @@
var HELLO_COMPONENT = "\ var HELLO_COMPONENT = `
var HelloMessage = React.createClass({\n\ var HelloMessage = React.createClass({
render: function() {\n\ render: function() {
return <div>Hello {this.props.name}</div>;\n\ return <div>Hello {this.props.name}</div>;
}\n\ }
});\n\ });
\n\
React.renderComponent(<HelloMessage name=\"John\" />, mountNode);\
";
React.renderComponent( React.render(<HelloMessage name="John" />, mountNode);
`;
React.render(
<ReactPlayground codeText={HELLO_COMPONENT} />, <ReactPlayground codeText={HELLO_COMPONENT} />,
document.getElementById('helloExample') document.getElementById('helloExample')
); );

66
_js/examples/markdown.js

@ -1,37 +1,37 @@
var MARKDOWN_COMPONENT = "\ var MARKDOWN_COMPONENT = `
var converter = new Showdown.converter();\n\ var converter = new Showdown.converter();
\n\
var MarkdownEditor = React.createClass({\n\
getInitialState: function() {\n\
return {value: 'Type some *markdown* here!'};\n\
},\n\
handleChange: function() {\n\
this.setState({value: this.refs.textarea.getDOMNode().value});\n\
},\n\
render: function() {\n\
return (\n\
<div className=\"MarkdownEditor\">\n\
<h3>Input</h3>\n\
<textarea\n\
onChange={this.handleChange}\n\
ref=\"textarea\"\n\
defaultValue={this.state.value} />\n\
<h3>Output</h3>\n\
<div\n\
className=\"content\"\n\
dangerouslySetInnerHTML={{\n\
__html: converter.makeHtml(this.state.value)\n\
}}\n\
/>\n\
</div>\n\
);\n\
}\n\
});\n\
\n\
React.renderComponent(<MarkdownEditor />, mountNode);\
";
React.renderComponent( var MarkdownEditor = React.createClass({
getInitialState: function() {
return {value: 'Type some *markdown* here!'};
},
handleChange: function() {
this.setState({value: this.refs.textarea.getDOMNode().value});
},
render: function() {
return (
<div className="MarkdownEditor">
<h3>Input</h3>
<textarea
onChange={this.handleChange}
ref="textarea"
defaultValue={this.state.value} />
<h3>Output</h3>
<div
className="content"
dangerouslySetInnerHTML={{
__html: converter.makeHtml(this.state.value)
}}
/>
</div>
);
}
});
React.render(<MarkdownEditor />, mountNode);
`;
React.render(
<ReactPlayground codeText={MARKDOWN_COMPONENT} />, <ReactPlayground codeText={MARKDOWN_COMPONENT} />,
document.getElementById('markdownExample') document.getElementById('markdownExample')
); );

48
_js/examples/timer.js

@ -1,28 +1,28 @@
var TIMER_COMPONENT = "\ var TIMER_COMPONENT = `
var Timer = React.createClass({\n\ var Timer = React.createClass({
getInitialState: function() {\n\ getInitialState: function() {
return {secondsElapsed: 0};\n\ return {secondsElapsed: 0};
},\n\ },
tick: function() {\n\ tick: function() {
this.setState({secondsElapsed: this.state.secondsElapsed + 1});\n\ this.setState({secondsElapsed: this.state.secondsElapsed + 1});
},\n\ },
componentDidMount: function() {\n\ componentDidMount: function() {
this.interval = setInterval(this.tick, 1000);\n\ this.interval = setInterval(this.tick, 1000);
},\n\ },
componentWillUnmount: function() {\n\ componentWillUnmount: function() {
clearInterval(this.interval);\n\ clearInterval(this.interval);
},\n\ },
render: function() {\n\ render: function() {
return (\n\ return (
<div>Seconds Elapsed: {this.state.secondsElapsed}</div>\n\ <div>Seconds Elapsed: {this.state.secondsElapsed}</div>
);\n\ );
}\n\ }
});\n\ });
\n\
React.renderComponent(<Timer />, mountNode);\
";
React.renderComponent( React.render(<Timer />, mountNode);
`;
React.render(
<ReactPlayground codeText={TIMER_COMPONENT} />, <ReactPlayground codeText={TIMER_COMPONENT} />,
document.getElementById('timerExample') document.getElementById('timerExample')
); );

77
_js/examples/todo.js

@ -1,42 +1,43 @@
var TODO_COMPONENT = "\ var TODO_COMPONENT = `
var TodoList = React.createClass({\n\ var TodoList = React.createClass({
render: function() {\n\ render: function() {
var createItem = function(itemText) {\n\ var createItem = function(itemText) {
return <li>{itemText}</li>;\n\ return <li>{itemText}</li>;
};\n\ };
return <ul>{this.props.items.map(createItem)}</ul>;\n\ return <ul>{this.props.items.map(createItem)}</ul>;
}\n\ }
});\n\ });
var TodoApp = React.createClass({\n\ var TodoApp = React.createClass({
getInitialState: function() {\n\ getInitialState: function() {
return {items: [], text: ''};\n\ return {items: [], text: ''};
},\n\ },
onChange: function(e) {\n\ onChange: function(e) {
this.setState({text: e.target.value});\n\ this.setState({text: e.target.value});
},\n\ },
handleSubmit: function(e) {\n\ handleSubmit: function(e) {
e.preventDefault();\n\ e.preventDefault();
var nextItems = this.state.items.concat([this.state.text]);\n\ var nextItems = this.state.items.concat([this.state.text]);
var nextText = '';\n\ var nextText = '';
this.setState({items: nextItems, text: nextText});\n\ this.setState({items: nextItems, text: nextText});
},\n\ },
render: function() {\n\ render: function() {
return (\n\ return (
<div>\n\ <div>
<h3>TODO</h3>\n\ <h3>TODO</h3>
<TodoList items={this.state.items} />\n\ <TodoList items={this.state.items} />
<form onSubmit={this.handleSubmit}>\n\ <form onSubmit={this.handleSubmit}>
<input onChange={this.onChange} value={this.state.text} />\n\ <input onChange={this.onChange} value={this.state.text} />
<button>{'Add #' + (this.state.items.length + 1)}</button>\n\ <button>{'Add #' + (this.state.items.length + 1)}</button>
</form>\n\ </form>
</div>\n\ </div>
);\n\ );
}\n\ }
});\n\ });
React.renderComponent(<TodoApp />, mountNode);\
";
React.renderComponent( React.render(<TodoApp />, mountNode);
`;
React.render(
<ReactPlayground codeText={TODO_COMPONENT} />, <ReactPlayground codeText={TODO_COMPONENT} />,
document.getElementById('todoExample') document.getElementById('todoExample')
); );

2
_js/html-jsx.js

@ -78,5 +78,5 @@ var HELLO_COMPONENT = "\
} }
}); });
React.renderComponent(<HTMLtoJSXComponent />, document.getElementById('jsxCompiler')); React.render(<HTMLtoJSXComponent />, document.getElementById('jsxCompiler'));
}()); }());

4
_js/jsx-compiler.js

@ -5,7 +5,7 @@ var HelloMessage = React.createClass({\n\
}\n\ }\n\
});\n\ });\n\
\n\ \n\
React.renderComponent(<HelloMessage name=\"John\" />, mountNode);\ React.render(<HelloMessage name=\"John\" />, mountNode);\
"; ";
function transformer(harmony, code) { function transformer(harmony, code) {
@ -39,7 +39,7 @@ var CompilerPlayground = React.createClass({
); );
}, },
}); });
React.renderComponent( React.render(
<CompilerPlayground />, <CompilerPlayground />,
document.getElementById('jsxCompiler') document.getElementById('jsxCompiler')
); );

4
_js/live_editor.js

@ -190,7 +190,7 @@ var ReactPlayground = React.createClass({
try { try {
var compiledCode = this.compileCode(); var compiledCode = this.compileCode();
if (this.props.renderCode) { if (this.props.renderCode) {
React.renderComponent( React.render(
<CodeMirrorEditor codeText={compiledCode} readOnly={true} />, <CodeMirrorEditor codeText={compiledCode} readOnly={true} />,
mountNode mountNode
); );
@ -199,7 +199,7 @@ var ReactPlayground = React.createClass({
} }
} catch (err) { } catch (err) {
this.setTimeout(function() { this.setTimeout(function() {
React.renderComponent( React.render(
<div className="playgroundError">{err.toString()}</div>, <div className="playgroundError">{err.toString()}</div>,
mountNode mountNode
); );

2
_posts/2014-10-16-react-v0.12-rc1.md

@ -106,7 +106,7 @@ You do NOT need to change the way to define `key` and `ref`, only if you need to
## Breaking Change: Default Props Resolution ## Breaking Change: Default Props Resolution
This is a subtle difference but `defaultProps` are now resolved at `ReactElement` creation time instead of when it's mounted. This is means that we can avoid allocating an extra object for the resolve props. This is a subtle difference but `defaultProps` are now resolved at `ReactElement` creation time instead of when it's mounted. This is means that we can avoid allocating an extra object for the resolved props.
You will primarily see this breaking if you're also using `transferPropsTo`. You will primarily see this breaking if you're also using `transferPropsTo`.

127
_posts/2014-10-28-react-v0.12.md

@ -0,0 +1,127 @@
---
title: React v0.12
author: Paul O’Shannessy
---
We're happy to announce the availability of React v0.12! After over a week of baking as the release candidate, we uncovered and fixed a few small issues. Thanks to all of you who upgraded and gave us feedback!
We have talked a lot about some of the bigger changes in this release. [We introduced new terminology](/react/blog/2014/10/14/introducing-react-elements.html) and changed APIs to clean up and simplify some of the concepts of React. [We also made several changes to JSX](/react/blog/2014/10/16/react-v0.12-rc1.html) and deprecated a few functions. We won't go into depth about these changes again but we encourage you to read up on these changes in the linked posts. We'll summarize these changes and discuss some of the other changes and how they may impact you below. As always, a full changelog is also included below.
The release is available for download:
* **React**
Dev build with warnings: <http://fb.me/react-0.12.0.js>
Minified build for production: <http://fb.me/react-0.12.0.min.js>
* **React with Add-Ons**
Dev build with warnings: <http://fb.me/react-with-addons-0.12.0.js>
Minified build for production: <http://fb.me/react-with-addons-0.12.0.min.js>
* **In-Browser JSX transformer**
<http://fb.me/JSXTransformer-0.12.0.js>
We've also published version `0.12.0` of the `react` and `react-tools` packages on npm and the `react` package on bower.
## New Terminology & Updated APIs
v0.12 is bringing about some new terminology. [We introduced](/react/blog/2014/10/14/introducing-react-elements.html) this 2 weeks ago and we've also documented it in [a new section of the documentation](/react/docs/glossary.html). As a part of this, we also corrected many of our top-level APIs to align with the terminology. `Component` has been removed from all of our `React.render*` methods. While at one point the argument you passed to these functions was called a Component, it no longer is. You are passing ReactElements. To align with `render` methods in your component classes, we decided to keep the top-level functions short and sweet. `React.renderComponent` is now `React.render`.
We also corrected some other misnomers. `React.isValidComponent` actually determines if the argument is a ReactElement, so it has been renamed to `React.isValidElement`. In the same vein, `React.PropTypes.component` is now `React.PropTypes.element` and `React.PropTypes.renderable` is now `React.PropTypes.node`.
The old methods will still work but will warn upon first use. They will be removed in v0.13.
## JSX Changes
[We talked more in depth about these before](/react/blog/2014/10/16/react-v0.12-rc1.html#jsx-changes), so here are the highlights.
* No more `/** @jsx React.DOM */`!
* We no longer transform to a straight function call. `<Component/>` now becomes `React.createElement(Component)`
* DOM components don't make use of `React.DOM`, instead we pass the tag name directly. `<div/>` becomes `React.createElement('div')`
* We introduced spread attributes as a quick way to transfer props.
## DevTools Improvements, No More `__internals`
For months we've gotten complaints about the React DevTools message. It shouldn't have logged the up-sell message when you were already using the DevTools. Unfortunately this was because the way we implemented these tools resulted in the DevTools knowing about React, but not the reverse. We finally gave this some attention and enabled React to know if the DevTools are installed. We released an update to the devtools several weeks ago making this possible. Extensions in Chrome should auto-update so you probably already have the update installed!
As a result of this update, we no longer need to expose several internal modules to the world. If you were taking advantage of this implementation detail, your code will break. `React.__internals` is no more.
## License Change - BSD
We updated the license on React to the BSD 3-Clause license with an explicit patent grant. Previously we used the Apache 2 license. These licenses are very similar and our extra patent grant is equivalent to the grant provided in the Apache license. You can still use React with the confidence that we have granted the use of any patents covering it. This brings us in line with the same licensing we use across the majority of our open source projects at Facebook.
You can read the full text of the [LICENSE](https://github.com/facebook/react/blob/master/LICENSE) and [`PATENTS`](https://github.com/facebook/react/blob/master/PATENTS) files on GitHub.
- - -
## Changelog
### React Core
#### Breaking Changes
* `key` and `ref` moved off props object, now accessible on the element directly
* React is now BSD licensed with accompanying Patents grant
* Default prop resolution has moved to Element creation time instead of mount time, making them effectively static
* `React.__internals` is removed - it was exposed for DevTools which no longer needs access
* Composite Component functions can no longer be called directly - they must be wrapped with `React.createFactory` first. This is handled for you when using JSX.
#### New Features
* Spread operator (`{...}`) introduced to deprecate `this.transferPropsTo`
* Added support for more HTML attributes: `acceptCharset`, `classID`, `manifest`
#### Deprecations
* `React.renderComponent` --> `React.render`
* `React.renderComponentToString` --> `React.renderToString`
* `React.renderComponentToStaticMarkup` --> `React.renderToStaticMarkup`
* `React.isValidComponent` --> `React.isValidElement`
* `React.PropTypes.component` --> `React.PropTypes.element`
* `React.PropTypes.renderable` --> `React.PropTypes.node`
* **DEPRECATED** `React.isValidClass`
* **DEPRECATED** `instance.transferPropsTo`
* **DEPRECATED** Returning `false` from event handlers to preventDefault
* **DEPRECATED** Convenience Constructor usage as function, instead wrap with `React.createFactory`
* **DEPRECATED** use of `key={null}` to assign implicit keys
#### Bug Fixes
* Better handling of events and updates in nested results, fixing value restoration in "layered" controlled components
* Correctly treat `event.getModifierState` as case sensitive
* Improved normalization of `event.charCode`
* Better error stacks when involving autobound methods
* Removed DevTools message when the DevTools are installed
* Correctly detect required language features across browsers
* Fixed support for some HTML attributes:
* `list` updates correctly now
* `scrollLeft`, `scrollTop` removed, these should not be specified as props
* Improved error messages
### React With Addons
#### New Features
* `React.addons.batchedUpdates` added to API for hooking into update cycle
#### Breaking Changes
* `React.addons.update` uses `assign` instead of `copyProperties` which does `hasOwnProperty` checks. Properties on prototypes will no longer be updated correctly.
#### Bug Fixes
* Fixed some issues with CSS Transitions
### JSX
#### Breaking Changes
* Enforced convention: lower case tag names are always treated as HTML tags, upper case tag names are always treated as composite components
* JSX no longer transforms to simple function calls
#### New Features
* `@jsx React.DOM` no longer required
* spread (`{...}`) operator introduced to allow easier use of props
#### Bug Fixes
* JSXTransformer: Make sourcemaps an option when using APIs directly (eg, for react-rails)

44
docs/02-displaying-data.md

@ -77,12 +77,50 @@ React components are very simple. You can think of them as simple function that
We strongly believe that components are the right way to separate concerns rather than "templates" and "display logic." We think that markup and the code that generates it are intimately tied together. Additionally, display logic is often very complex and using template languages to express it becomes cumbersome. We strongly believe that components are the right way to separate concerns rather than "templates" and "display logic." We think that markup and the code that generates it are intimately tied together. Additionally, display logic is often very complex and using template languages to express it becomes cumbersome.
We've found that the best solution for this problem is to generate markup directly from the JavaScript code such that you can use all of the expressive power of a real programming language to build UIs. In order to make this easier, we've added a very simple, **optional** HTML-like syntax for the function calls that generate markup called JSX. We've found that the best solution for this problem is to generate HTML and component trees directly from the JavaScript code such that you can use all of the expressive power of a real programming language to build UIs.
**JSX lets you write JavaScript function calls with HTML syntax.** To generate a link in React using pure JavaScript you'd write: `React.DOM.a({href: 'http://facebook.github.io/react/'}, 'Hello React!')`. With JSX this becomes `<a href="http://facebook.github.io/react/">Hello React!</a>`. We've found this has made building React apps easier and designers tend to prefer the syntax, but everyone has their own workflow, so **JSX is not required to use React.** In order to make this easier, we've added a very simple, **optional** HTML-like syntax to create these React tree nodes.
JSX is very small; the "hello, world" example above uses every feature of JSX. To learn more about it, see [JSX in depth](/react/docs/jsx-in-depth.html). Or see the transform in action in [our live JSX compiler](/react/jsx-compiler.html). **JSX lets you create JavaScript objects using HTML syntax.** To generate a link in React using pure JavaScript you'd write:
`React.createElement('a', {href: 'http://facebook.github.io/react/'}, 'Hello!')`
With JSX this becomes:
`<a href="http://facebook.github.io/react/">Hello!</a>`
We've found this has made building React apps easier and designers tend to prefer the syntax, but everyone has their own workflow, so **JSX is not required to use React.**
JSX is very small. To learn more about it, see [JSX in depth](/react/docs/jsx-in-depth.html). Or see the transform in action in [our live JSX compiler](/react/jsx-compiler.html).
JSX is similar to HTML, but not exactly the same. See [JSX gotchas](/react/docs/jsx-gotchas.html) for some key differences. JSX is similar to HTML, but not exactly the same. See [JSX gotchas](/react/docs/jsx-gotchas.html) for some key differences.
The easiest way to get started with JSX is to use the in-browser `JSXTransformer`. We strongly recommend that you don't use this in production. You can precompile your code using our command-line [react-tools](http://npmjs.org/package/react-tools) package. The easiest way to get started with JSX is to use the in-browser `JSXTransformer`. We strongly recommend that you don't use this in production. You can precompile your code using our command-line [react-tools](http://npmjs.org/package/react-tools) package.
## React without JSX
JSX is completely optional. You don't have to use JSX with React. You can create these trees through `React.createElement`. The first argument is the tag, pass a properties object as the second argument and children to the third argument.
```javascript
var child = React.createElement('li', null, 'Text Content');
var root = React.createElement('ul', { className: 'my-list' }, child);
React.render(root, document.body);
```
As a convenience you can create short-hand factory function to create elements from custom components.
```javascript
var Factory = React.createFactory(ComponentClass);
...
var root = Factory({ custom: 'prop' });
React.render(root, document.body);
```
React already have built-in factories for common HTML tags:
```javascript
var root = React.DOM.ul({ className: 'my-list' },
React.DOM.li(null, 'Text Content')
);
```

2
docs/02-displaying-data.zh-CN.md

@ -76,7 +76,7 @@ React 组件非常简单。你可以认为它们就是简单的函数,接受 `
我们得出解决这个问题最好的方案是通过 JavaScript 直接生成模板,这样你就可以用一个真正语言的所有表达能力去构建用户界面。为了使这变得更简单,我们做了一个非常简单、**可选**类似 HTML 语法 ,通过函数调用即可生成模板的编译器,称为 JSX。 我们得出解决这个问题最好的方案是通过 JavaScript 直接生成模板,这样你就可以用一个真正语言的所有表达能力去构建用户界面。为了使这变得更简单,我们做了一个非常简单、**可选**类似 HTML 语法 ,通过函数调用即可生成模板的编译器,称为 JSX。
**JSX 让你可以用 HTML 语法去写 JavaScript 函数调用** 为了在 React 生成一个链接,通过纯 JavaScript 你可以这么写: `React.DOM.a({href: 'http://facebook.github.io/react/'}, 'Hello React!')`。通过 JSX 这就变成了 `<a href="http://facebook.github.io/react/">Hello React!</a>`。我们发现这会使搭建 React 应用更加简单,设计师也偏向用这用语法,但是每个人可以有它们自己的工作流,所以**JSX 不是必须用的。** **JSX 让你可以用 HTML 语法去写 JavaScript 函数调用** 为了在 React 生成一个链接,通过纯 JavaScript 你可以这么写: `React.createElement('a', {href: 'http://facebook.github.io/react/'}, 'Hello React!')`。通过 JSX 这就变成了 `<a href="http://facebook.github.io/react/">Hello React!</a>`。我们发现这会使搭建 React 应用更加简单,设计师也偏向用这用语法,但是每个人可以有它们自己的工作流,所以**JSX 不是必须用的。**
JSX 非常小;上面“hello, world”的例子使用了 JSX 所有的特性。想要了解更多,请看 [深入理解 JSX](/react/docs/jsx-in-depth.html)。或者直接使用[在线 JSX 编译器](/react/jsx-compiler.html)观察变化过程。 JSX 非常小;上面“hello, world”的例子使用了 JSX 所有的特性。想要了解更多,请看 [深入理解 JSX](/react/docs/jsx-in-depth.html)。或者直接使用[在线 JSX 编译器](/react/jsx-compiler.html)观察变化过程。

145
docs/02.1-jsx-in-depth.md

@ -3,39 +3,58 @@ id: jsx-in-depth
title: JSX in Depth title: JSX in Depth
permalink: jsx-in-depth.html permalink: jsx-in-depth.html
prev: displaying-data.html prev: displaying-data.html
next: jsx-gotchas.html next: jsx-spread.html
--- ---
JSX is a JavaScript XML syntax transform recommended for use [JSX](http://facebook.github.io/jsx/) is a JavaScript syntax extension that looks similar to XML. You can use a simple JSX syntactic transform with React.
with React.
## Why JSX? ## Why JSX?
React works out of the box without JSX. Simply construct your markup using the You don't have to use JSX with React. You can just use plain JS. However, we recommend using JSX because it is a concise and familiar syntax for defining tree structures with attributes.
functions on `React.DOM`. For example, here's how to construct a simple link:
It's more familiar for casual developers such as designers.
XML has the benefit of balanced open and closing tags. This helps make large trees easier to read than function calls or object literals.
It doesn't alter the semantics of JavaScript.
## HTML Tags vs. React Components
React can either render HTML tags (strings) or React components (classes).
To render a HTML tag, just use lower-case tag names in JSX:
```javascript ```javascript
var link = React.DOM.a({href: 'http://facebook.github.io/react'}, 'React'); var myDivElement = <div className="foo" />;
React.render(myDivElement, document.body);
``` ```
We recommend using JSX for many reasons: To render a React Component, just a local variable that starts with an upper-case letter:
* It's easier to visualize the structure of the DOM. ```javascript
* Designers are more comfortable making changes. var MyComponent = React.createClass({/*...*/});
* It's familiar for those who have used MXML or XAML. var myElement = <MyComponent someProperty={true} />;
React.render(myElement, document.body);
```
React's JSX uses the upper vs. lower case convention to distinguish between local component classes and HTML tags.
> Note:
>
> Since JSX is JavaScript, identifiers such as `class` and `for` are discouraged
> as XML attribute names. Instead, React DOM components expect DOM property
> names like `className` and `htmlFor`, respectively.
## The Transform ## The Transform
JSX transforms from an XML-like syntax into native JavaScript. XML elements and React JSX transforms from an XML-like syntax into native JavaScript. XML elements, attributes and children are transformed into arguments to `React.createElement`.
attributes are transformed into function calls and objects, respectively.
```javascript ```javascript
var Nav; var Nav;
// Input (JSX): // Input (JSX):
var app = <Nav color="blue" />; var app = <Nav color="blue" />;
// Output (JS): // Output (JS):
var app = Nav({color:"blue"}); var app = React.createElement(Nav, {color:"blue"});
``` ```
Notice that in order to use `<Nav />`, the `Nav` variable must be in scope. Notice that in order to use `<Nav />`, the `Nav` variable must be in scope.
@ -47,7 +66,11 @@ var Nav, Profile;
// Input (JSX): // Input (JSX):
var app = <Nav color="blue"><Profile>click</Profile></Nav>; var app = <Nav color="blue"><Profile>click</Profile></Nav>;
// Output (JS): // Output (JS):
var app = Nav({color:"blue"}, Profile(null, "click")); var app = React.createElement(
Nav,
{color:"blue"},
React.createElement(Profile, null, "click")
);
``` ```
Use the [JSX Compiler](/react/jsx-compiler.html) to try out JSX and see how it Use the [JSX Compiler](/react/jsx-compiler.html) to try out JSX and see how it
@ -55,72 +78,14 @@ desugars into native JavaScript, and the
[HTML to JSX converter](/react/html-jsx.html) to convert your existing HTML to [HTML to JSX converter](/react/html-jsx.html) to convert your existing HTML to
JSX. JSX.
If you want to use JSX, the [Getting Started](/react/docs/getting-started.html) guide shows If you want to use JSX, the [Getting Started](/react/docs/getting-started.html) guide shows how to setup compilation.
how to setup compilation.
> Note: > Note:
> >
> Details about the code transform are given here to increase understanding, but > The JSX expression always evaluates to a ReactElement. The actual
> your code should not rely on these implementation details. > implementation details may vary. An optimized mode could inline the
> ReactElement as an object literal to bypass the validation code in
> `React.createElement`.
## React and JSX
React and JSX are independent technologies, but JSX was primarily built with
React in mind. The two valid uses of JSX are:
* To construct instances of React DOM components (`React.DOM.*`).
* To construct instances of composite components created with
`React.createClass()`.
### React DOM Components
To construct a `<div>` is to create a variable that refers to `React.DOM.div`.
```javascript
var div = React.DOM.div;
var app = <div className="appClass">Hello, React!</div>;
```
### React Composite Components
To construct an instance of a composite component, create a variable that
references the class.
```javascript
var MyComponent = React.createClass({/*...*/});
var app = <MyComponent someProperty={true} />;
```
JSX will infer the component's name from the variable assignment and specify
the class's [displayName](/react/docs/component-specs.html#displayName) accordingly.
See [Multiple Components](/react/docs/multiple-components.html) to learn more about using composite components.
> Note:
>
> Since JSX is JavaScript, identifiers such as `class` and `for` are discouraged
> as XML attribute names. Instead, React DOM components expect attributes like
> `className` and `htmlFor`, respectively.
## DOM Convenience
Having to define variables for every type of DOM element can get tedious
(e.g. `var div, span, h1, h2, ...`). JSX provides a convenience to address this
problem:
```javascript
var Nav;
// Input (JSX):
var tree = <Nav><span /></Nav>;
// Output (JS):
var tree = Nav(null, React.DOM.span(null));
```
> Remember:
>
> JSX simply transforms elements into function calls and has no notion of the
> DOM.
## JavaScript Expressions ## JavaScript Expressions
@ -133,7 +98,10 @@ pair of curly braces (`{}`) instead of quotes (`""`).
// Input (JSX): // Input (JSX):
var person = <Person name={window.isLoggedIn ? window.name : ''} />; var person = <Person name={window.isLoggedIn ? window.name : ''} />;
// Output (JS): // Output (JS):
var person = Person({name: window.isLoggedIn ? window.name : ''}); var person = React.createElement(
Person,
{name: window.isLoggedIn ? window.name : ''}
);
``` ```
### Child Expressions ### Child Expressions
@ -144,7 +112,11 @@ Likewise, JavaScript expressions may be used to express children:
// Input (JSX): // Input (JSX):
var content = <Container>{window.isLoggedIn ? <Nav /> : <Login />}</Container>; var content = <Container>{window.isLoggedIn ? <Nav /> : <Login />}</Container>;
// Output (JS): // Output (JS):
var content = Container(null, window.isLoggedIn ? Nav(null) : Login(null)); var content = React.createElement(
Container,
null,
window.isLoggedIn ? React.createElement(Nav) : React.createElement(Login)
);
``` ```
### Comments ### Comments
@ -165,15 +137,6 @@ var content = (
); );
``` ```
> NOTE:
## Prior Work >
> JSX is similar to HTML, but not exactly the same. See [JSX gotchas](/react/docs/jsx-gotchas.html) for some key differences.
JSX is similar to several other JavaScript embedded XML language
proposals/projects. Some of the features of JSX that distinguish it from similar
efforts include:
* JSX is a simple syntactic transform.
* JSX neither provides nor requires a runtime library.
* JSX does not alter or add to the semantics of JavaScript.
JSX is similar to HTML, but not exactly the same. See [JSX gotchas](/react/docs/jsx-gotchas.html) for some key differences.

71
docs/02.2-jsx-spread.md

@ -0,0 +1,71 @@
---
id: jsx-spread
title: JSX Spread Attributes
permalink: jsx-spread.html
prev: jsx-in-depth.html
next: jsx-gotchas.html
---
If you know all the properties that you want to place on a component a head of time, it is easy to use JSX:
```javascript
var component = <Component foo={x} bar={y} />;
```
## Mutating Props is Bad, mkay
If you don't know which properties you want to set, you might be tempted to add them onto the object later:
```javascript
var component = <Component />;
component.props.foo = x; // bad
component.props.bar = y; // also bad
```
This is an anti-pattern because it means that we can't help you check the right propTypes until way later. This means that your propTypes errors end up with a cryptic stack trace.
The props should be considered immutable at this point. Mutating the props object somewhere else could cause unexpected consequences so ideally it would be a frozen object at this point.
## Spread Attributes
Now you can use a new feature of JSX called spread attributes:
```javascript
var props = {};
props.foo = x;
props.bar = y;
var component = <Component {...props} />;
```
The properties of the object that you pass in are copied onto the component's props.
You can use this multiple times or combine it with other attributes. The specification order is important. Later attributes override previous ones.
```javascript
var props = { foo: 'default' };
var component = <Component {...props} foo={'override'} />;
console.log(component.props.foo); // 'override'
```
## What's with the weird `...` notation?
The `...` operator (or spread operator) is already supported for [arrays in ES6](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Operators/Spread_operator). There is also an ES7 proposal for [Object Rest and Spread Properties](https://github.com/sebmarkbage/ecmascript-rest-spread).
In fact, you can already use this in our code base as an experimental syntax:
```javascript
var oldObj = { foo: 'hello', bar: 'world' };
var newObj = { ...oldObj, foo: 'hi' };
console.log(newObj.foo); // 'hi';
console.log(newObj.bar); // 'world';
```
Merging two objects can be expressed as:
```javascript
var ab = { ...a, ...b };
```
> Note:
>
> Use the [JSX command-line tool](http://npmjs.org/package/react-tools) with the `--harmony` flag to activate the experimental ES7 syntax.

2
docs/02.2-jsx-gotchas.md → docs/02.3-jsx-gotchas.md

@ -2,7 +2,7 @@
id: jsx-gotchas id: jsx-gotchas
title: JSX Gotchas title: JSX Gotchas
permalink: jsx-gotchas.html permalink: jsx-gotchas.html
prev: jsx-in-depth.html prev: jsx-spread.html
next: interactivity-and-dynamic-uis.html next: interactivity-and-dynamic-uis.html
--- ---

2
docs/05-reusable-components.md

@ -3,7 +3,7 @@ id: reusable-components
title: Reusable Components title: Reusable Components
permalink: reusable-components.html permalink: reusable-components.html
prev: multiple-components.html prev: multiple-components.html
next: forms.html next: transferring-props.html
--- ---
When designing interfaces, break down the common design elements (buttons, form fields, layout components, etc) into reusable components with well-defined interfaces. That way, the next time you need to build some UI you can write much less code, which means faster development time, fewer bugs, and fewer bytes down the wire. When designing interfaces, break down the common design elements (buttons, form fields, layout components, etc) into reusable components with well-defined interfaces. That way, the next time you need to build some UI you can write much less code, which means faster development time, fewer bugs, and fewer bytes down the wire.

159
docs/06-transferring-props.md

@ -0,0 +1,159 @@
---
id: transferring-props
title: Transferring Props
permalink: transferring-props.html
prev: reusable-components.html
next: forms.html
---
It's a common pattern in React to wrap a component in an abstraction. The outer component exposes a simple property to do something that might have more complex implementation details.
You can use [JSX spread attributes](/react/docs/jsx-spread.html) to merge the old props with additional values:
```javascript
return <Component {...this.props} more="values" />;
```
If you don't use JSX, you can use any object helper such as ES6 `Object.assign` or Underscore `_.extend`:
```javascript
return Component(Object.assign({}, this.props, { more: 'values' }));
```
The rest of this tutorial explains best practices. It uses JSX and experimental ES7 syntax.
## Manual Transfer
Most of the time you should explicitly pass the properties down. That ensures that you only exposes a subset of the inner API, one that you know will work.
```javascript
var FancyCheckbox = React.createClass({
render: function() {
var fancyClass = this.props.checked ? 'FancyChecked' : 'FancyUnchecked';
return (
<div className={fancyClass} onClick={this.props.onClick}>
{this.props.children}
</div>
);
}
});
React.renderComponent(
<FancyCheckbox checked={true} onClick={console.log}>
Hello world!
</FancyCheckbox>,
document.body
);
```
But what about the `name` prop? Or the `title` prop? Or `onMouseOver`?
## Transferring with `...` in JSX
Sometimes it's fragile and tedious to pass every property along. In that case you can use [destructuring assignment](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Operators/Destructuring_assignment) with rest properties to extract a set of unknown properties.
List out all the properties that you would like to consume, followed by `...other`.
```javascript
var { checked, ...other } = this.props;
```
This ensures that you pass down all the props EXCEPT the ones you're consuming yourself.
```javascript
var FancyCheckbox = React.createClass({
render: function() {
var { checked, ...other } = this.props;
var fancyClass = checked ? 'FancyChecked' : 'FancyUnchecked';
// `other` contains { onClick: console.log } but not the checked property
return (
<div {...other} className={fancyClass} />
);
}
});
React.renderComponent(
<FancyCheckbox checked={true} onClick={console.log}>
Hello world!
</FancyCheckbox>,
document.body
);
```
> NOTE:
>
> In the example above, the `checked` prop is also a valid DOM attribute. If you didn't use destructuring in this way you might inadvertently pass it along.
Always use the destructuring pattern when transferring unknown `other` props.
```javascript
var FancyCheckbox = React.createClass({
render: function() {
var fancyClass = this.props.checked ? 'FancyChecked' : 'FancyUnchecked';
// ANTI-PATTERN: `checked` would be passed down to the inner component
return (
<div {...this.props} className={fancyClass} />
);
}
});
```
## Consuming and Transferring the Same Prop
If your component wants to consume a property but also pass it along, you can repass it explicitly `checked={checked}`. This is preferable to passing the full `this.props` object since it's easier to refactor and lint.
```javascript
var FancyCheckbox = React.createClass({
render: function() {
var { checked, title, ...other } = this.props;
var fancyClass = checked ? 'FancyChecked' : 'FancyUnchecked';
var fancyTitle = checked ? 'X ' + title : 'O ' + title;
return (
<label>
<input {...other}
checked={checked}
className={fancyClass}
type="checkbox"
/>
{fancyTitle}
</label>
);
}
});
```
> NOTE:
>
> Order matters. By putting the `{...other}` before your JSX props you ensure that the consumer of your component can't override them. In the example above we have guaranteed that the input will be of type `"checkbox"`.
## Rest and Spread Properties `...`
Rest properties allow you to extract the remaining properties from an object into a new object. It excludes every other property listed in the destructuring pattern.
This is an experimental implementation of an [ES7 proposal](https://github.com/sebmarkbage/ecmascript-rest-spread).
```javascript
var { x, y, ...z } = { x: 1, y: 2, a: 3, b: 4 };
x; // 1
y; // 2
z; // { a: 3, b: 4 }
```
> Note:
>
> Use the [JSX command-line tool](http://npmjs.org/package/react-tools) with the `--harmony` flag to activate the experimental ES7 syntax.
## Transferring with Underscore
If you don't use JSX, you can use a library to achieve the same pattern. Underscore supports `_.omit` to filter out properties and `_.extend` to copy properties onto a new object.
```javascript
var FancyCheckbox = React.createClass({
render: function() {
var checked = this.props.checked;
var other = _.omit(this.props, 'checked');
var fancyClass = checked ? 'FancyChecked' : 'FancyUnchecked';
return (
React.DOM.div(_.extend({}, other, { className: fancyClass }))
);
}
});
```

2
docs/06-forms.md → docs/07-forms.md

@ -2,7 +2,7 @@
id: forms id: forms
title: Forms title: Forms
permalink: forms.html permalink: forms.html
prev: reusable-components.html prev: transferring-props.html
next: working-with-the-browser.html next: working-with-the-browser.html
--- ---

0
docs/07-working-with-the-browser.md → docs/08-working-with-the-browser.md

0
docs/07.1-more-about-refs.md → docs/08.1-more-about-refs.md

0
docs/08-tooling-integration.md → docs/09-tooling-integration.md

0
docs/09-addons.md → docs/10-addons.md

10
docs/09.1-animation.md → docs/10.1-animation.md

@ -164,17 +164,21 @@ This is called when the `willLeave` `callback` is called (at the same time as `c
By default `ReactTransitionGroup` renders as a `span`. You can change this behavior by providing a `component` prop. For example, here's how you would render a `<ul>`: By default `ReactTransitionGroup` renders as a `span`. You can change this behavior by providing a `component` prop. For example, here's how you would render a `<ul>`:
```javascript{1} ```javascript{1}
<ReactTransitionGroup component={React.DOM.ul}> <ReactTransitionGroup component="ul">
... ...
</ReactTransitionGroup> </ReactTransitionGroup>
``` ```
Every DOM component is under `React.DOM`. However, `component` does not need to be a DOM component. It can be any React component you want; even ones you've written yourself! Every DOM component that React can render is available for use. However, `component` does not need to be a DOM component. It can be any React component you want; even ones you've written yourself!
> Note:
>
> Prior to v0.12, when using DOM components, the `component` prop needed to be a reference to `React.DOM.*`. Since the component is simply passed to `React.createElement`, it must now be a string. Composite components must pass the factory.
Any additional, user-defined, properties will be become properties of the rendered component. For example, here's how you would you render a `<ul>` with css class: Any additional, user-defined, properties will be become properties of the rendered component. For example, here's how you would you render a `<ul>` with css class:
```javascript{1} ```javascript{1}
<ReactTransitionGroup component={React.DOM.ul} className="animated-list"> <ReactTransitionGroup component="ul" className="animated-list">
... ...
</ReactTransitionGroup> </ReactTransitionGroup>
``` ```

0
docs/09.2-form-input-binding-sugar.md → docs/10.2-form-input-binding-sugar.md

0
docs/09.3-class-name-manipulation.md → docs/10.3-class-name-manipulation.md

6
docs/09.4-test-utils.md → docs/10.4-test-utils.md

@ -43,13 +43,13 @@ object mockComponent(function componentClass, string? mockTagName)
Pass a mocked component module to this method to augment it with useful methods that allow it to be used as a dummy React component. Instead of rendering as usual, the component will become a simple `<div>` (or other tag if `mockTagName` is provided) containing any provided children. Pass a mocked component module to this method to augment it with useful methods that allow it to be used as a dummy React component. Instead of rendering as usual, the component will become a simple `<div>` (or other tag if `mockTagName` is provided) containing any provided children.
### isDescriptorOfType ### isElementOfType
```javascript ```javascript
boolean isDescriptorOfType(ReactDescriptor descriptor, function componentClass) boolean isElementOfType(ReactElement element, function componentClass)
``` ```
Returns true if `descriptor` is an instance of a React `componentClass`. Returns true if `element` is a ReactElement whose type is of a React `componentClass`.
### isDOMComponent ### isDOMComponent

0
docs/09.5-clone-with-props.md → docs/10.5-clone-with-props.md

0
docs/09.6-update.md → docs/10.6-update.md

0
docs/09.7-pure-render-mixin.md → docs/10.7-pure-render-mixin.md

0
docs/09.8-perf.md → docs/10.8-perf.md

2
docs/getting-started.md

@ -81,7 +81,7 @@ The file `build/helloworld.js` is autogenerated whenever you make a change.
```javascript{2} ```javascript{2}
React.render( React.render(
React.DOM.h1(null, 'Hello, world!'), React.createElement('h1', null, 'Hello, world!'),
document.getElementById('example') document.getElementById('example')
); );
``` ```

2
docs/getting-started.zh-CN.md

@ -80,7 +80,7 @@ jsx --watch src/ build/
```javascript{2} ```javascript{2}
React.render( React.render(
React.DOM.h1(null, 'Hello, world!'), React.createElement('h1', null, 'Hello, world!'),
document.getElementById('example') document.getElementById('example')
); );
``` ```

22
docs/ref-01-top-level-api.md

@ -26,15 +26,15 @@ For more information about the specification object, see [Component Specs and Li
```javascript ```javascript
ReactComponent render( ReactComponent render(
ReactComponent component, ReactElement element,
DOMElement container, DOMElement container,
[function callback] [function callback]
) )
``` ```
Render a React component into the DOM in the supplied `container` and return a reference to the component. Render a ReactElement into the DOM in the supplied `container` and return a reference to the component.
If the React component was previously rendered into `container`, this will perform an update on it and only mutate the DOM as necessary to reflect the latest React component. If the ReactElement was previously rendered into `container`, this will perform an update on it and only mutate the DOM as necessary to reflect the latest React component.
If the optional callback is provided, it will be executed after the component is rendered or updated. If the optional callback is provided, it will be executed after the component is rendered or updated.
@ -73,27 +73,19 @@ string renderToStaticMarkup(ReactComponent component)
Similar to `renderToString`, except this doesn't create extra DOM attributes such as `data-react-id`, that React uses internally. This is useful if you want to use React as a simple static page generator, as stripping away the extra attributes can save lots of bytes. Similar to `renderToString`, except this doesn't create extra DOM attributes such as `data-react-id`, that React uses internally. This is useful if you want to use React as a simple static page generator, as stripping away the extra attributes can save lots of bytes.
### React.isValidClass
```javascript ### React.isValidElement
boolean isValidClass(* factory)
```
Verifies the factory is a React class descriptor. See `React.createClass`.
### React.isValidComponent
```javascript ```javascript
boolean isValidComponent(* object) boolean isValidElement(* object)
``` ```
Verifies the object is a React component descriptor. Verifies the object is a ReactElement.
### React.DOM ### React.DOM
`React.DOM` provides all of the standard HTML tags needed to build a React app. You generally don't use it directly; instead, just include it as part of the `/** @jsx React.DOM */` docblock. `React.DOM` provides convenience wrappers around `React.createElement` for DOM components. These should only be used when not using JSX. For example, `React.DOM.div(null, 'Hello World!')`
### React.PropTypes ### React.PropTypes

27
docs/ref-02-component-api.md

@ -70,33 +70,6 @@ bool isMounted()
`isMounted()` returns true if the component is rendered into the DOM, false otherwise. You can use this method to guard asynchronous calls to `setState()` or `forceUpdate()`. `isMounted()` returns true if the component is rendered into the DOM, false otherwise. You can use this method to guard asynchronous calls to `setState()` or `forceUpdate()`.
### transferPropsTo
```javascript
ReactComponent transferPropsTo(ReactComponent targetComponent)
```
Transfer properties from this component to a target component that have not already been set on the target component. After the props are updated, `targetComponent` is returned as a convenience. This function is useful when creating simple HTML-like components:
```javascript
var Avatar = React.createClass({
render: function() {
return this.transferPropsTo(
<img src={"/avatars/" + this.props.userId + ".png"} userId={null} />
);
}
});
// <Avatar userId={17} width={200} height={200} />
```
Properties that are specified directly on the target component instance (such as `src` and `userId` in the above example) will not be overwritten by `transferPropsTo`.
> Note:
>
> Use `transferPropsTo` with caution; it encourages tight coupling and makes it easy to accidentally introduce implicit dependencies between components. When in doubt, it's safer to explicitly copy the properties that you need onto the child component.
### setProps ### setProps
```javascript ```javascript

16
docs/ref-04-tags-and-attributes.md

@ -20,8 +20,8 @@ button canvas caption cite code col colgroup data datalist dd del details dfn
dialog div dl dt em embed fieldset figcaption figure footer form h1 h2 h3 h4 h5 dialog div dl dt em embed fieldset figcaption figure footer form h1 h2 h3 h4 h5
h6 head header hr html i iframe img input ins kbd keygen label legend li link h6 head header hr html i iframe img input ins kbd keygen label legend li link
main map mark menu menuitem meta meter nav noscript object ol optgroup option main map mark menu menuitem meta meter nav noscript object ol optgroup option
output p param pre progress q rp rt ruby s samp script section select small output p param picture pre progress q rp rt ruby s samp script section select
source span strong style sub summary sup table tbody td textarea tfoot th small source span strong style sub summary sup table tbody td textarea tfoot th
thead time title tr track u ul var video wbr thead time title tr track u ul var video wbr
``` ```
@ -52,15 +52,15 @@ For a list of events, see [Supported Events](/react/docs/events.html).
These standard attributes are supported: These standard attributes are supported:
``` ```
accept accessKey action allowFullScreen allowTransparency alt async accept acceptCharset accessKey action allowFullScreen allowTransparency alt
autoComplete autoFocus autoPlay cellPadding cellSpacing charSet checked async autoComplete autoPlay cellPadding cellSpacing charSet checked classID
className cols colSpan content contentEditable contextMenu controls coords className cols colSpan content contentEditable contextMenu controls coords
crossOrigin data dateTime defer dir disabled download draggable encType form crossOrigin data dateTime defer dir disabled download draggable encType form
formNoValidate frameBorder height hidden href hrefLang htmlFor httpEquiv icon formNoValidate frameBorder height hidden href hrefLang htmlFor httpEquiv icon
id label lang list loop max maxLength mediaGroup method min multiple muted id label lang list loop manifest max maxLength media mediaGroup method min
name noValidate open pattern placeholder poster preload radioGroup readOnly rel multiple muted name noValidate open pattern placeholder poster preload
required role rows rowSpan sandbox scope scrollLeft scrolling scrollTop radioGroup readOnly rel required role rows rowSpan sandbox scope scrolling
seamless selected shape size span spellCheck src srcDoc srcSet start step seamless selected shape size sizes span spellCheck src srcDoc srcSet start step
style tabIndex target title type useMap value width wmode style tabIndex target title type useMap value width wmode
``` ```

1
docs/ref-08-reconciliation.md

@ -3,6 +3,7 @@ id: reconciliation
title: Reconciliation title: Reconciliation
permalink: reconciliation.html permalink: reconciliation.html
prev: special-non-dom-attributes.html prev: special-non-dom-attributes.html
next: glossary.html
--- ---
React's key design decision is to make the API seem like it re-renders the whole app on every update. This makes writing applications a lot easier but is also an incredible challenge to make it tractable. This article explains how with powerful heuristics we managed to turn a O(n<sup>3</sup>) problem into a O(n) one. React's key design decision is to make the API seem like it re-renders the whole app on every update. This makes writing applications a lot easier but is also an incredible challenge to make it tractable. This article explains how with powerful heuristics we managed to turn a O(n<sup>3</sup>) problem into a O(n) one.

192
docs/ref-09-glossary.md

@ -0,0 +1,192 @@
---
id: glossary
title: React (Virtual) DOM Terminology
permalink: glossary.html
prev: reconciliation.html
---
In React's terminology, there are five core types that are important to distinguish:
- [ReactElement / ReactElement Factory](#react-elements)
- [ReactNode](#react-nodes)
- [ReactComponent / ReactComponent Class](#react-components)
## React Elements
The primary type in React is the `ReactElement`. It has four properties: `type`, `props`, `key` and `ref`. It has no methods and nothing on the prototype.
You can create one of these object through `React.createElement`.
```javascript
var root = React.createElement('div');
```
To render a new tree into the DOM, you create `ReactElement`s and pass them to `React.render` a long with a regular DOM `Element` (`HTMLElement` or `SVGElement`). `ReactElement`s are not to be confused with DOM `Element`s. A `ReactElement` is a light, stateless, immutable, virtual representation of a DOM `Element`. It is a virtual DOM.
```javascript
React.render(root, document.body);
```
To add properties to a DOM element, pass a properties object as the second argument and children to the third argument.
```javascript
var child = React.createElement('li', null, 'Text Content');
var root = React.createElement('ul', { className: 'my-list' }, child);
React.render(root, document.body);
```
If you use React JSX, then these `ReactElement`s are created for you. So this is equivalent:
```javascript
var root = <ul className="my-list">
<li>Text Content</li>
</ul>;
React.render(root, document.body);
```
__Factories__
A `ReactElement`-factory is simply a function that generates a `ReactElement` with a particular `type` property. React has a built-in helper for you to create factories. It's effectively just:
```javascript
function createFactory(type){
return React.createElement.bind(null, type);
}
```
It allows you to create a convenient short-hand instead of typing out `React.createElement('div')` all the time.
```javascript
var div = React.createFactory('div');
var root = div({ className: 'my-div' });
React.render(root, document.body);
```
React already have built-in factories for common HTML tags:
```javascript
var root = React.DOM.ul({ className: 'my-list' },
React.DOM.li(null, 'Text Content')
);
```
If you are using JSX you have no need for factories. JSX already provides a convenient short-hand for creating `ReactElement`s.
## React Nodes
A `ReactNode` can be either:
- `ReactElement`
- `string` (aka `ReactText`)
- `number` (aka `ReactText`)
- Array of `ReactNode`s (aka `ReactFragment`)
These are used as properties of other `ReactElement`s to represent children. Effectively they create a tree of `ReactElement`s.
## React Components
You can use React using only `ReactElement`s but to really take advantage of React, you'll want to use `ReactComponent`s to create encapsulations with embedded state.
A `ReactComponent` Class is simply just a JavaScript class (or "constructor function").
```javascript
var MyComponent = React.createClass({
render: function() {
...
}
});
```
When this constructor is invoked it is expected to return an object with at least a `render` method on it. This object is referred to as a `ReactComponent`.
```javascript
var component = new MyComponent(props); // never do this
```
Other than for testing, you would normally __never__ call this constructor yourself. React calls it for you.
Instead, you pass the `ReactComponent` Class to `createElement` you get a `ReactElement`.
```javascript
var element = React.createElement(MyComponent);
```
OR using JSX:
```javascript
var element = <MyComponent />;
```
When this is passed to `React.render`, React will call the constructor for you and create a `ReactComponent`, which returned.
```javascript
var component = React.render(element, document.body);
```
If you keep calling `React.render` with the same type of `ReactElement` and the same container DOM `Element` it always returns the same instance. This instance is stateful.
```javascript
var componentA = React.render(<MyComponent />, document.body);
var componentB = React.render(<MyComponent />, document.body);
componentA === componentB; // true
```
This is why you shouldn't construct your own instance. Instead, `ReactElement` is a virtual `ReactComponent` before it gets constructed. An old and new `ReactElement` can be compared to see if a new `ReactComponent` instance is created or if the existing one is reused.
The `render` method of a `ReactComponent` is expected to return another `ReactElement`. This allows these components to be composed. Ultimately the render resolves into `ReactElement` with a `string` tag which instantiates a DOM `Element` instance and inserts it into the document.
## Formal Type Definitions
__Entry Point__
```
React.render = (ReactElement, HTMLElement | SVGElement) => ReactComponent;
```
__Nodes and Elements__
```
type ReactNode = ReactElement | ReactFragment | ReactText;
type ReactElement = ReactComponentElement | ReactDOMElement;
type ReactDOMElement = {
type : string,
props : {
children : ReactNodeList,
className : string,
etc.
},
key : string | boolean | number | null,
ref : string | null
};
type ReactComponentElement<TProps> = {
type : ReactClass<TProps>,
props : TProps,
key : string | boolean | number | null,
ref : string | null
};
type ReactFragment = Array<ReactNode | ReactEmpty>;
type ReactNodeList = ReactNode | ReactEmpty;
type ReactText = string | number;
type ReactEmpty = null | undefined | boolean;
```
__Classes and Components__
```
type ReactClass<TProps> = (TProps) => ReactComponent<TProps>;
type ReactComponent<TProps> = {
props : TProps,
render : () => ReactElement
};
```

6
docs/tutorial.md

@ -90,14 +90,14 @@ The first thing you'll notice is the XML-ish syntax in your JavaScript. We have
var CommentBox = React.createClass({displayName: 'CommentBox', var CommentBox = React.createClass({displayName: 'CommentBox',
render: function() { render: function() {
return ( return (
React.DOM.div({className: "commentBox"}, React.createElement('div', {className: "commentBox"},
"Hello, world! I am a CommentBox." "Hello, world! I am a CommentBox."
) )
); );
} }
}); });
React.render( React.render(
CommentBox(null), React.createElement(CommentBox, null),
document.getElementById('content') document.getElementById('content')
); );
``` ```
@ -158,7 +158,7 @@ var CommentBox = React.createClass({
}); });
``` ```
Notice how we're mixing HTML tags and components we've built. HTML components are regular React components, just like the ones you define, with one difference. The JSX compiler will automatically rewrite HTML tags to "React.DOM.tagName" expressions and leave everything else alone. This is to prevent the pollution of the global namespace. Notice how we're mixing HTML tags and components we've built. HTML components are regular React components, just like the ones you define, with one difference. The JSX compiler will automatically rewrite HTML tags to `React.createElement(tagName)` expressions and leave everything else alone. This is to prevent the pollution of the global namespace.
### Component Properties ### Component Properties

4
tips/03-if-else-in-JSX.md

@ -14,7 +14,7 @@ next: self-closing-tag.html
React.render(<div id="msg">Hello World!</div>, mountNode); React.render(<div id="msg">Hello World!</div>, mountNode);
// Is transformed to this JS: // Is transformed to this JS:
React.render(React.DOM.div({id:"msg"}, "Hello World!"), mountNode); React.render(React.createElement("div", {id:"msg"}, "Hello World!"), mountNode);
``` ```
This means that `if` statements don't fit in. Take this example: This means that `if` statements don't fit in. Take this example:
@ -24,7 +24,7 @@ This means that `if` statements don't fit in. Take this example:
<div id={if (condition) { 'msg' }}>Hello World!</div> <div id={if (condition) { 'msg' }}>Hello World!</div>
// Is transformed to this JS: // Is transformed to this JS:
React.DOM.div({id: if (condition) { 'msg' }}, "Hello World!"); React.createElement("dov", {id: if (condition) { 'msg' }}, "Hello World!");
``` ```
That's not valid JS. You probably want to make use of a ternary expression: That's not valid JS. You probably want to make use of a ternary expression:

6
tips/16-references-to-components.md

@ -13,14 +13,14 @@ If you're using React components in a larger non-React application or transition
var myComponent = React.render(<MyComponent />, myContainer); var myComponent = React.render(<MyComponent />, myContainer);
``` ```
Keep in mind, however, that the "constructor" of a component doesn't return a component instance! It's just a **descriptor**: a lightweight representation that tells React what the mounted component should look like. Keep in mind, however, that the JSX doesn't return a component instance! It's just a **ReactElement**: a lightweight representation that tells React what the mounted component should look like.
```js ```js
var myComponent = <MyComponent />; // This is just a descriptor. var myComponentElement = <MyComponent />; // This is just a ReactElement.
// Some code here... // Some code here...
myComponent = React.render(myComponent, myContainer); var myComponentInstance = React.render(myComponentElement, myContainer);
``` ```
> Note: > Note:

Loading…
Cancel
Save