85
85
</ head >
86
86
< body >
87
87
< section class ="container ">
88
- < h1 > JSX Syntax</ h1 >
89
- < p >
90
- JSX extends javascript to support embedding xml tags and compiles to javascript.
91
- </ p >
88
+ < h1 > Application as a hierarchy of components</ h1 >
92
89
< div class ="row ">
93
- < div class ="col-sm-6 ">
94
- < span > JSX:</ span >
95
- < div class ="sourceCode " data-source ="jsxSyntaxSource "> </ div >
96
- </ div >
97
- < div class ="col-sm-6 ">
98
- < span > Transpiled Javascript</ span >
99
- < div class ="sourceCode " data-source ="jsxTanslatedSyntaxSource "> </ div >
90
+ < div class ="col-sm-12 ">
91
+ < p >
92
+ A web application is presented by defining a structural DOM to be rendered.
93
+ When the state of the application changes, perhaps due to a user event, the DOM
94
+ structure changes to represent the new state. React.js divides up the DOM rendering
95
+ and interactivity into components with each component being responsible for its own
96
+ state and presentation.
97
+ </ p >
100
98
</ div >
101
99
</ div >
102
100
</ section >
103
101
< section class ="container ">
104
- < h1 > Component </ h1 >
102
+ < h1 > Components as Actors </ h1 >
105
103
< div class ="row ">
106
104
< div class ="col-sm-4 ">
107
105
< ul >
108
- < li > Defining a component allows you to use a variable as a JSX tag</ li >
109
- < li > Components are structured like HTML by having children and properties</ li >
110
- < li > A component is an Actor that receives messages, updates state, and sends messages</ li >
106
+ < li > A component is dependent on three state containers: context, props, state</ li >
107
+ < li > Components render a Virtual DOM that is applied to the UI</ li >
108
+ < li > Whenever a component's state container changes it is rerendered</ li >
109
+ < li > Messages may be received and trigger state changes</ li >
110
+ < li > Components may have callbacks set in context or props</ li >
111
111
</ ul >
112
112
113
113
</ div >
114
114
< div class ="col-sm-8 ">
115
- < div class ="sourceCode " data-source ="defineTagSource "> </ div >
115
+ < img style ="width: 100%; " src =" " />
116
116
</ div >
117
117
</ div >
118
118
</ section >
119
119
< section class ="container ">
120
- < h1 > Render</ h1 >
120
+ < h1 > Components as Tags</ h1 >
121
+ < div class ="row ">
122
+ < div class ="col-sm-12 ">
123
+ < h2 > JSX Syntax</ h2 >
124
+ < p >
125
+ React JSX is transpiled to Javascript. This allows for mixing html and javascript syntax.
126
+ </ p >
127
+ </ div >
128
+ </ div >
129
+ < div class ="row ">
130
+ < div class ="col-sm-6 ">
131
+ < span > JSX:</ span >
132
+ < div class ="sourceCode " data-source ="jsxSyntaxSource "> </ div >
133
+ </ div >
134
+ < div class ="col-sm-6 ">
135
+ < span > Transpiled Javascript</ span >
136
+ < div class ="sourceCode " data-source ="jsxTanslatedSyntaxSource "> </ div >
137
+ </ div >
138
+ </ div >
121
139
< div class ="row ">
122
140
< div class ="col-sm-4 ">
123
- < p >
124
- Render is called after the component's internal state changes.
125
- The virtual DOM is compared against the actual DOM to generate a DOM diff.
126
- This DOM diff is applied to the actual DOM to minimize redrawing.
127
- </ p >
128
141
< ul >
129
- < li > The "render" method returns a virtual DOM</ li >
130
- < li > Returned virtual DOM must have one root element or be null to render nothing</ li >
142
+ < li > Defining a component allows you to use a variable as a JSX tag</ li >
131
143
< li > Brackets ("{}") are used to evaluate javascript within the tags.</ li >
144
+ < li > The attributes of a tag are mapped to as props for the component state</ li >
145
+ < li > The contents are mapped to the props.children for the component state</ li >
132
146
</ ul >
133
147
< div class ="result " id ="defineRender "> </ div >
134
148
</ div >
@@ -138,7 +152,7 @@ <h1>Render</h1>
138
152
</ div >
139
153
</ section >
140
154
< section class ="container ">
141
- < h1 > Properties</ h1 >
155
+ < h2 > Properties</ h2 >
142
156
< div class ="row ">
143
157
< div class ="col-sm-4 ">
144
158
< ul >
@@ -154,7 +168,7 @@ <h1>Properties</h1>
154
168
</ div >
155
169
</ section >
156
170
< section class ="container ">
157
- < h1 > State & Events</ h1 >
171
+ < h2 > State & Events</ h2 >
158
172
< div class ="row ">
159
173
< div class ="col-sm-4 ">
160
174
< ul >
0 commit comments