Build a user interface with React
ECA React - November 21st 2018
data:image/s3,"s3://crabby-images/41153/411531e5aa83d0ac1c86e679e5b355e0a9b07cfc" alt=""
Reference: https://codewithmosh.com/
Last time...
data:image/s3,"s3://crabby-images/7fb8a/7fb8a155ae98a01233bc0d95417c64046f4ca7d7" alt=""
- Let / Const
- Destructuring
- Arrow functions
- Higher-order functions
- Template Literals
- Classes
data:image/s3,"s3://crabby-images/90c69/90c69347aa6158e6d385af6d4027ceb5f1a854f8" alt=""
Modules
class Person {
constructor(name) {
this.name = name;
this.age = 20
}
speak() {
console.log(`My name is ${ this.name } and I am ${ this.age }`);
}
}
const issam = new Person("Issam");
const remi = new Person("Remi");
issam.speak();
class Person {
constructor(name) {
this.name = name;
}
speak() {
console.log(`My name is ${ this.name }`);
}
}
class PokemonTrainer extends Person {
constructor(name, favoritePokemon) {
super(name);
this.favoritePokemon = favoritePokemon;
}
train() {
console.log("train");
}
}
const red = new PokemonTrainer("Red", "Pikachu");
class Person {
constructor(name) {
this.name = name;
}
speak() {
console.log('speak');
}
}
export Person
import { Person } from './person'
class PokemonTrainer extends Person {
constructor(name, favoritePokemon) {
super(name);
this.favoritePokemon = favoritePokemon;
}
train() {
console.log("train");
}
}
export PokemonTrainer
person.js
pokemonTrainer.js
import { PokemonTrainer } from './pokemonTrainer'
const red = new PokemonTrainer("Red", "Pikachu");
index.js
Named and default exports
class Person {
constructor(name) {
this.name = name;
}
}
export Person
import { Person } from './person'
const issam = new Person("Issam");
person.js
index.js
class Person {
constructor(name) {
this.name = name;
}
}
export default Person
import Person from './person'
const issam = new Person("Issam");
person.js
index.js
Named exports
Default exports
What is React?
A library to build user interfaces
Facebook
Component-based
Popular
data:image/s3,"s3://crabby-images/41153/411531e5aa83d0ac1c86e679e5b355e0a9b07cfc" alt=""
What is a component?
A component is a part of the UI
data:image/s3,"s3://crabby-images/1b01d/1b01d56a5f65b3b455bd3d452035b6ebfd7241fa" alt=""
Root
Search
bar
Filters
Houses list
House
Description
Price
import React, { Component } from 'react'
class House extends Component {
state = { }
render() {
}
}
React Element
What is the virtual DOM?
-
"Virtual" representation of a UI kept in memory
-
Synced with the "real" DOM by ReactDOM
Real DOM
Virtual DOM
DOM Element
React Element
React
reacts to change
data:image/s3,"s3://crabby-images/6f278/6f27831d679508247e8a7b5df60e7780039a26a0" alt=""
Project: Pokeshop
data:image/s3,"s3://crabby-images/27f23/27f2307a60338143f6f37575e7f44007a34c3947" alt=""
data:image/s3,"s3://crabby-images/e252d/e252d9a8f8023894c86efd5236de7d0a5b229886" alt=""
data:image/s3,"s3://crabby-images/110e0/110e0ed03e66bd19f14865815e4a8a3066ecc25e" alt=""
data:image/s3,"s3://crabby-images/12f4a/12f4a3b505b13c87812c3da55a3a8604346e776c" alt=""
data:image/s3,"s3://crabby-images/e01eb/e01eb50a0537bc56716ba326a577b8f9bedd20e0" alt=""
data:image/s3,"s3://crabby-images/b0202/b020299b549009366d49567522813a4ae5f64016" alt=""
2
+
-
3
+
-
5
+
-
0
+
-
0
+
-
Total
10
Environment setup
Tools
Must Have extensions
-
Simple React Snippets
-
Prettier
Create React App
-
One Dependency: There is just one build dependency. It uses Webpack, Babel, ESLint, and other amazing projects
-
No Configuration Required
-
No Lock-In: You can “eject” to a custom setup at any time
├── node_modules/ # Installed necessary packages
├── public/ # Static files
│ ├── favicon.ico
│ └── index.html
├── src/ # Application root
│ ├── components/ # Application components
│ │ ├── board.js
│ │ ├── game.js
│ │ └── square.js
│ ├── index.css
│ ├── index.js
│ ├── logo.svg
│ └── utils/ # Utility files
│ └── index.js
├── package.json
├── README.md
└── yarn.lock
4 directories, 12 files
# Configuration files for Jest & Webpack
# Polyfills for Promises and Object.assign()
├── config/
│ ├── env.js
│ ├── jest/
│ │ ├── cssTransform.js
│ │ └── fileTransform.js
│ ├── paths.js
│ ├── polyfills.js
│ ├── webpack.config.dev.js
│ └── webpack.config.prod.js
├── node_modules/ # Installed packages necessary for Create-React-App
├── package.json
├── public/
│ ├── favicon.ico
│ └── index.html
├── scripts/ # Exposed React Scripts
│ ├── build.js
│ ├── start.js
│ └── test.js
├── src/
│ ├── components/
│ │ ├── board.js
│ │ ├── game.js
│ │ └── square.js
│ ├── index.css
│ ├── index.js
│ ├── logo.svg
│ └── utils/
│ └── index.js
└── yarn.lock
8 directories, 21 files
Our first component: PokeCounter
data:image/s3,"s3://crabby-images/b0202/b020299b549009366d49567522813a4ae5f64016" alt=""
2
Increment
"Hello World"
import React from "react";
import ReactDOM from "react-dom";
import "bootstrap/dist/css/bootstrap.min.css";
import PokeCounter from "./components/pokeCounter";
ReactDOM.render(<PokeCounter />, document.getElementById("root"));
index.js
import React, { Component } from "react";
class PokeCounter extends Component {
render() {
return <h1>Hello World</h1>;
}
}
export default PokeCounter;
pokeCounter.jsx
Multiple children
import React, { Component } from "react";
class PokeCounter extends Component {
render() {
return (
<React.Fragment>
<h1>Hello World</h1>
<button>Increment</button>
</React.Fragment>
);
}
}
export default PokeCounter;
Necessary to have a parent element!
Embedding expressions
import React, { Component } from "react";
class PokeCounter extends Component {
state = {
count: 1
};
formatCount() {
return this.state.count === 0 ? "Zero" : this.state.count;
}
render() {
return (
<React.Fragment>
<h1>{this.formatCount()}</h1>
<button>Increment</button>
</React.Fragment>
);
}
}
export default PokeCounter;
Setting attributes
class PokeCounter extends Component {
state = {
count: 1
};
formatCount() {
return this.state.count === 0 ? "Zero" : this.state.count;
}
render() {
return (
<React.Fragment>
<span className="badge badge-primary m-2" style={{ fontSize: 20 }}>
{this.formatCount()}
</span>
<button className="btn btn-secondary btn-sm">Increment</button>
</React.Fragment>
);
}
}
See you next wednesday!
data:image/s3,"s3://crabby-images/41153/411531e5aa83d0ac1c86e679e5b355e0a9b07cfc" alt=""
React (1/5) - Our first component
By zolani
React (1/5) - Our first component
ECA React - November 21st 2018
- 732