Skip to content

Commit 5260713

Browse files
committed
attempt a better explanation for state
1 parent 877d306 commit 5260713

File tree

1 file changed

+40
-26
lines changed

1 file changed

+40
-26
lines changed

lesson1.html

Lines changed: 40 additions & 26 deletions
Original file line numberDiff line numberDiff line change
@@ -85,50 +85,64 @@
8585
</head>
8686
<body>
8787
<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>
9289
<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>
10098
</div>
10199
</div>
102100
</section>
103101
<section class="container">
104-
<h1>Component</h1>
102+
<h1>Components as Actors</h1>
105103
<div class="row">
106104
<div class="col-sm-4">
107105
<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>
111111
</ul>
112112

113113
</div>
114114
<div class="col-sm-8">
115-
<div class="sourceCode" data-source="defineTagSource"></div>
115+
<img style="width: 100%;" src="" />
116116
</div>
117117
</div>
118118
</section>
119119
<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>
121139
<div class="row">
122140
<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>
128141
<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>
131143
<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>
132146
</ul>
133147
<div class="result" id="defineRender"></div>
134148
</div>
@@ -138,7 +152,7 @@ <h1>Render</h1>
138152
</div>
139153
</section>
140154
<section class="container">
141-
<h1>Properties</h1>
155+
<h2>Properties</h2>
142156
<div class="row">
143157
<div class="col-sm-4">
144158
<ul>
@@ -154,7 +168,7 @@ <h1>Properties</h1>
154168
</div>
155169
</section>
156170
<section class="container">
157-
<h1>State &amp; Events</h1>
171+
<h2>State &amp; Events</h2>
158172
<div class="row">
159173
<div class="col-sm-4">
160174
<ul>

0 commit comments

Comments
 (0)