Edited copy for grammar/flow (#26155)

I went through the text to fix some minor grammatical issues (eg, it's/its) and make the text descriptions flow better. I also added some extra code sections to clearly mark where there is code that will be typed into the editor.
This commit is contained in:
Stefan
2019-02-12 11:07:45 -05:00
committed by Randell Dawson
parent 86b8cee810
commit 25730a92ac

View File

@@ -47,25 +47,25 @@ ReactDOM.render(
);
```
2. React is Declarative for most part in which we are concerned more with What to do rather than How to do a specific task. Declarative programming is a programming paradigm that expresses the logic of a computation without describing its control flow.
Declarative programming comes with certain advantages such as reduced side effects(occurs when we modify any state or mutating something or making an API request), minimizing mutability(mostly abstracted), enhanced readability, less bugs.
2. React is Declarative for the most part, meaning we are concerned more with What to do, rather than How to do, a specific task. Declarative programming is a paradigm that expresses the logic of a computation without describing its control flow.
This comes with certain advantages such as reduced side effects (such as when we modify any state or mutating something or making an API request), minimizing mutability (mostly abstracted), enhanced readability, and fewer bugs.
3. Unidirectional dataflow. UI in React is actually the function of the state that means as the state updates it updates the UI as well. So our UI progresses as the state changes.
3. Unidirectional dataflow. Data flows only from the state to the User Interface, and not the other way around. UI in React is actually the function of the state, so as the state updates, the UI updates with it. So our UI progresses as the state changes.
## Advantages of React
Some reasons to use React are:
1. Fast. Apps made in React can handle complex updates and still feel quick and responsive.
2. Modular. Instead of writing large, dense files of code, you can write many smaller, reusable files. React's modularity can be a beautiful solution to JavaScript's [maintainability problems](https://en.wikipedia.org/wiki/Spaghetti_code).
3. Scalable. Large programs that display a lot of changing data are where React performs best.
4. Flexible. You can use React for interesting projects that have nothing to do with making a web app. People are still figuring out React's potential. [There's room to explore](https://medium.mybridge.co/22-amazing-open-source-react-projects-cb8230ec719f).
1. It's Fast. Apps made in React can handle complex updates and still feel quick and responsive.
2. It's Modular. Instead of writing large, dense files of code, you can write many smaller, reusable files. React's modularity can be a beautiful solution to JavaScript's [maintainability problems](https://en.wikipedia.org/wiki/Spaghetti_code).
3. It's Scalable. Large programs that display a lot of changing data are where React performs best.
4. It's Flexible. You can use React for interesting projects that have nothing to do with making a web app. People are still figuring out React's potential. [There's room to explore](https://medium.mybridge.co/22-amazing-open-source-react-projects-cb8230ec719f).
### Virtual DOM
React's magic comes from it's interpretation of the DOM and it's strategy for creating UIs.
React's magic comes from its interpretation of the DOM and its strategy for creating UIs.
React uses the virtual DOM to render an HTML tree virtually first, and then, every time a state changes and we get a new HTML tree that needs to be taken to the browsers DOM, instead of writing the whole new tree React will only write the difference between the new tree and the previous tree (since React has both trees in memory). This process is known as Tree Reconciliation.
React uses the virtual DOM to render an HTML tree virtually first. Then, every time a state changes and we get a new HTML tree that needs to be taken to the browsers DOM, instead of writing the whole new tree React will only write the difference between the new tree and the previous tree (since React has both trees in memory). This process is known as Tree Reconciliation.
### Reconciliation
@@ -88,7 +88,7 @@ In this article we are going to look at how we can get started with React using
### 1Set Up Boiler Plate Code with Emmet
Lets get started with step 1. Well begin with a file in our browser called “index.html”. Well begin with the boiler plate code HTML code. For a quick start I recommend using Emmet with whatever text editor you have and on the first line typing in `html:5` then pressing the shift key to get the code below. Or you can go ahead and copy and paste the code from below.
Lets get started with step 1. Well begin with a file in our browser called “index.html”. Well begin with the boiler plate HTML code. For a quick start I recommend using Emmet with whatever text editor you have, and on the first line typing in `html:5` then pressing the shift key to get the code below. Or you can go ahead and copy and paste the code from below.
```javascript
html:5
@@ -111,14 +111,14 @@ This will result in the following code:
</html>
```
We can fill in the title of “Time to React!”.
We can fill in the title as “Time to React!”.
This content will not appear in your webpage. Anything in the head section of the HTML file will be meta data that our browser will user to interpret our code in the body section. This title is going to be what appears on the tab for our page, not actually on the page.
This content will not appear in your webpage. Anything in the head section of the HTML file will be metadata that our browser will use to interpret our code in the body section. This title is going to be what appears on the tab for our page, not actually on the page.
### 2 - Get Script Tags to Harness the Power of React and Babel Libraries
Ok, item one is checked off of our list. Lets look at item two. We are going to set up our developer environment by using script tags to bring in React and Babel. This is not a real life developer environment. That would be quite an elaborate setup. It would also leave us with a lot of boiler plate code and libraries that would take us off subject of learning React basics. The goal of this series is to go over the basic syntax of React and get right into coding.
We are going to use `<script>` tags to bring in the React Library, the React DOM library (why), and the Babel library.
OK, item one is checked off of our list. Lets look at item two. We are going to set up our developer environment by using script tags to bring in React and Babel. This is not a real-life developer environment. That would be quite an elaborate setup, and leave us with a lot of boiler plate code and libraries that would take us off subject of learning React basics. The goal of this series is to go over the basic syntax of React and get right into coding.
We are going to use `<script>` tags to bring in the React Library, the React DOM library (why?), and the Babel library.
```javascript
<head>
@@ -137,18 +137,18 @@ We are going to use `<script>` tags to bring in the React Library, the React DOM
You are free to use more updated versions of these libraries as they come out. They should not create any breaking changes for the content we are covering.
What are we doing here?
The: HTML `<script>` element is used to embed or reference an executable script. The src attribute points to the external script files for the React library, ReactDOM library and Babel library.
This is like if you have an electric razor. It is literally no good to you no matter how fancy the electric razor unless you can plug it into the wall and gain access to electricity. Our React code we will write will be no good to us if our browser cant plug into these libraries to understand and interpret what we are going.
This is how our application is going to gain the power of React, it is going to be how we insert React into the Dom. The reason that we have React and ReactDOM as two different libraries is because there are use cases such as React Native where rendering to the DOM isnt needed for mobile development so the library was split for people to make the decision for what they need depending on the project they are working on. Because we will need our React to make it to the DOM well use both scripts.
The: HTML `<script>` element is used to embed or reference an executable script. The `src` attribute points to the external script files for the React library, ReactDOM library and Babel library.
This is like using an electric razor. No matter how fancy the razor, it's no good to you unless you can plug it into the wall and gain access to electricity. Our React code we will write will be no good to us if our browser cant plug into these libraries to understand and interpret what we are doing.
This is how our application is going to gain the power of React: it is how we insert React into the Dom. The reason that we have React and ReactDOM as two different libraries is because there are use cases such as React Native where rendering to the DOM isnt needed for mobile development. Accordingly, the library was split for people to make the decision for what they need depending on the project they are working on. Because we will need our React to make it to the DOM well use both scripts.
Babel is how we take advantage of ECMA script beyond ES5 and deal with something called JSX (JavaScript as XML) that we will use in React. Well take a deeper look at the magic of Babel in an upcoming lesson :)
Alright, we have completed steps 1 and 2. We have set up our boiler plate code and set up our developer environment.
Alright, we have completed steps 1 and 2: we have set up our boiler plate code and our developer environment.
### 3 - Render React to the DOM
Our next two steps will be to choose our location within DOM that we want to render our React content. And using another script tag for our React content within the body. Generally, as a good separations of concerns practice this would be in its own file then linked to this html document. Well do that later in upcoming lessons.
Our next step will be to choose our location within the DOM where we want to render our React content, using another script tag for our React content within the body. Generally, as a good separations of concerns practice, this would be in its own file then linked to this html document. Well do that later in upcoming lessons.
For now, well let this dwell within the body of the html document we are currently in.
Now we are going to look at how simple it is to choose a place on the DOM to render our React content.
Well go within the body. And best practice isnt just to throw React into the body tag to be displayed but to create a separate element, often a div, that you can treat as a root element to insert your React content.
Well go within the body. And best practice isnt just to throw React into the body tag to be displayed but to create a separate element, often a `<div>`, that you can treat as a root element to insert your React content.
```javascript
<body>
@@ -156,9 +156,9 @@ Well go within the body. And best practice isnt just to throw React into t
</body>
```
Well create a simple `<div>` element and give it an id of app. We are going to be able to target this location to insert our React content much the same way you might use CSS to target an id for styling of your choice.
Well create a simple `<div>` element and give it an id of `app`. We are going to be able to target this location to insert our React content much the same way you might use CSS to target an id for styling of your choice.
Any react content will be rendered within the div tags with the id of app. In the meantime well leave some text saying that “React has not rendered yet” If we see this when we preview our page it means that somewhere we missed rendering React.
Now, lets go ahead and create a script tag within our body where we will create with react for the first time. The syntax we are going to need for our script tag is to add an attribute of type”. This specifies the media type of the script. Above in our head we used an src attribute that pointed to the external script files for the React library, ReactDOM library and Babel library.
Now, lets go ahead and create a script tag within our body where we will create with React for the first time. The syntax we are going to need for our script tag is to add an attribute of `type`, which specifies the media type of the script. Above in our `<head>` we used a `src` attribute that pointed to the external script files for the React library, ReactDOM library and Babel library.
```javascript
<body>
@@ -168,8 +168,8 @@ Now, lets go ahead and create a script tag within our body where we will crea
</body>
```
The type of script that we are using well wrap in quotes and set it to `"text/babel"`.
Well need this ability to use babel right away as we work with JSX. First, we are going to render React to the DOM. We will use the `ReactDOM.render()` method to do this. This will be a method, and remember a method is just a function attached to an object. This method will take two arguments.
The `type` of script that we are using well wrap in quotes and set it to `"text/babel"`.
Well need this ability to use babel right away as we work with JSX. First, we are going to render React to the DOM. We will use the `ReactDOM.render()` method to do this. Remember: a method is just a function attached to an object. This method will take two arguments.
```javascript
<body>
@@ -180,7 +180,7 @@ Well need this ability to use babel right away as we work with JSX. First, we
</body>
```
The first argument is the what of react. The second argument is the “where” of the location you want it to be placed in the DOM.
The first argument is the "what" of React. The second is the “where”: location you want it to be placed in the DOM.
Lets start by calling our ReactDOM.render() method.
Our first argument is going to be our JSX.
@@ -196,13 +196,13 @@ Our first argument is going to be our JSX.
</body>
```
The [official react docs state](https://reactjs.org/docs/introducing-jsx.html): “This funny tag syntax is neither a string nor HTML. It is called JSX, and it is a syntax extension to JavaScript. We recommend using it with React to describe what the UI should look like. JSX may remind you of a template language, but it comes with the full power of JavaScript. JSX produces React “elements”.”
The [official React docs state](https://reactjs.org/docs/introducing-jsx.html): “This funny tag syntax is neither a string nor HTML. It is called JSX, and it is a syntax extension to JavaScript. We recommend using it with React to describe what the UI should look like. JSX may remind you of a template language, but it comes with the full power of JavaScript. JSX produces React “elements”.”
Often times, JSX freaks people out who have been developers for a while because it looks like HTML. At a very early age developers are taught separation of concerns. HTML has its place, CSS has its place and JavaScript has its place. JSX seems to blur the lines. You are using what looks like HTML but as Facebook says comes with the full power of JavaScript.
Often times, JSX freaks people out who have been developers for a while because it looks like HTML. At a very early age developers are taught separation of concerns. HTML has its place, CSS has its place and JavaScript has its place. JSX seems to blur the lines. You are using what looks like HTML but, as Facebook says, it comes with the full power of JavaScript.
This can freak out veterans so many react tutorials start without JSX which can be quite complex. We wont do that. Because this course is directed towards those who are very young in their careers you may not bring those red flags when you see this syntax.
This can freak out veterans so many react tutorials start without JSX, which can be quite complex. We wont do that. Because this course is directed towards those who are very young in their careers you may not see those red flags when you see this syntax.
And JSX is just really intuitive. You can probably quite easily read this code and see that this is going to be the largest header tag displaying the text “Hello World”. No mystery and pretty straightforward.
And JSX is just really intuitive. You can probably quite easily read this code and see that this is going to be the largest header tag displaying the text “Hello World”: no mystery and pretty straightforward.
Now, lets look at what our second argument would be.
```javascript
@@ -217,13 +217,13 @@ Now, lets look at what our second argument would be.
</body>
```
This is where we want our react content rendered to the dom. Youve probably done this quite a few times in the past. Well just type in `document.getElementById()`. And well pass into the argument of the id of app. And that is it. We will now target the div with the id of app to insert our react content.
This is where we want our React content rendered to the DOM. Youve probably done this quite a few times in the past. Well just type in `document.getElementById()`. And well pass into the argument of the id of app. And that's it. We will now target the `<div>` with the id of `app` to insert our React content.
We want to make sure our content is saved. Go ahead and open this up in the browser and you should see “Hello World”. As you can probably guess, using React is not the quickest or best way to create a Hello World app. We arent quite seeing the benefits of it yet. But now, we know that everything is working.
We want to make sure our content is saved. Go ahead and open this up in your browser, and you should see “Hello World”. As you can probably guess, using React is not the quickest or best way to create a Hello World app. We arent quite seeing the benefits of it yet. But now, we know that everything is working.
Go ahead and open up the console and look at the “elements”. You can do that on a mac with command + shift + j or on a On Windows and Linux: Ctrl + Shift + J
Go ahead and open up the console and look at the “elements”. You can do that on a mac with command + shift + j or on Windows or Linux with Ctrl + Shift + J.
If you click on the head tag we can see our script libraries we included. Then we can go down to body of our document. Lets click on our div with the id of app”. And when we do we see our `<h1>` tag with the content “Hello World”.
If you click on the head tag your can see the script libraries we included. Then we can go down to body of our document. Lets click on our div with the id of `app`, and see our `<h1>` tag with the content “Hello World”.
[View Entire Code Here](https://github.com/robgmerrill/hello-react/blob/master/section-one/index.html)
@@ -238,9 +238,9 @@ Get more information about it [here](https://github.com/facebook/create-react-ap
### Recap
So lets do a quick recap. In our head tag we grabbed the script tags for React, ReactDOM and Babel. These are the tools our browser needs in its meta data to read our React code and JSX in specific.
We then located the position within the DOM that we wanted to insert our React by creating an element div with the id of app.
Next, we created a script tag to input our React code. We used the ReactDOM.render() method that takes two arguments. The “what” of the React content, in this case our JSX, and the second argument is the “where” that you want to insert the React content into the DOM. In this case it is the location with the id of app.
So lets do a quick recap. In our `<head>` tag we grabbed the script tags for React, ReactDOM and Babel. These are the tools our browser needs in its meta data to read our React code and JSX in specific.
We then located the position within the DOM that we wanted to insert our React by creating an element div with the id of `app`.
Next, we created a script tag to input our React code. We used the ReactDOM.render() method that takes two arguments. The “what” of the React content, in this case our JSX, and the second argument is the “where” that you want to insert the React content into the DOM. In this case it is the location with the id of `app`.
As an alternative to JSX, you can use ES6 and Javascript's compiler like Babel. [https://babeljs.io/](https://babeljs.io/)