An online markdown blog and knowledge repository.
Componentization: Breaking down larger code into smaller components. Think of the way React is designed.
Canvas: Not a good alternative available at this point. Send feedback to Canvas.
Readings: Try to get a basic, overview understanding, but don't worry about deep understanding on a single reading.
1-on-1: Ask Sheyna how she can help me make the best of my experience in Code301.
background-image: url()
.Working with other people's code is:
Content Agnostic: Design components so they will work with multiple types of content. "Generally specific" variable assignments and references.
Note: ALWAYS check your Node -v before utilizing create-react-app to scaffold a new project. Use nvm use nn
to change to the connect Node version for the React version and scaffolding requirements.
Passing by value and passing by reference.
Javascript is going to be 'weird' about this.
When copying let variables, they copy the value as assigned.
When copying objects (arrays and object), a reference is copied, not the value.
Shallow copy => a reference is copied to the source value.
Deep copy => values are copied to the new object instance.
Ways to push deep copy: map, for-each, for loop.
Better way to deep copy: Use the spread operator [...srcArr]
Make a request from our front-end to an API.
Web Request Response Cycle.
FE: Our own computer. A user interface. Example: A website.
BE: Some other computer. A service that responds to requests. Example: A database.
An API helps another app 'run better'.
Use an API to get data from a remote server, rather than a local file.
GET: Ask for data and either get it or get an error.
We will focus on GET this week.
POST, DELETE, and PUT are also used in REST.
Next week will add POST, DELETE, and PUT.
Base URL: The http address of the server that hosts the API.
Endpoint: A keyword like 'search'.
Query Strings: Start with a '?' followed by a key=value.
Query String Concatenation: Performed with the &
symbol.
Multiple Query Strings: ?key=value&anotherKey=value
Requests are Objects: Objects are made of key:value pairs.
Requests are composed of 1 or more query strings concatenations.
variableName.data.result
.swapi.dev Single-response, or multiple response (collections) are possible.
Import Axios so it can be used: import axios from 'axios';
Set the state, using an empty array.
Create an event handler e.g.:
// after the constructor (and state) and before render(){}
handleSubmit = (event) => {
event.preventDefault();
let swData = axios.get('https://swapi.dev.api.people/?page=1');
};
Assign an output variable in the render() function like:
let swListItems = this.state.starWarsData.map((char, idx) => {
return <li key={idx}>{char}</li>;
});
Create a UL element and pass-in {swListItems}
to add the JSX 'li' items.
npm -install: download dependencies.
npm -i packageName: Adds packageName to the node_modules folder.
npm start: run the project.
Do not share API keys with others - IT IS YOURS and is used like a billing register (for some APIs).
my.locationiq.com (go get registered).
Request an API Key via API Access Tokens.
API Keys have properties that can allow/deny list via:
Update .gitignore to block '.env' (it will be greyed-out in VSCode).
When making an API call that requires an Access Token, using Axios, use a 'template literal' to insert the key value.
${}
for the API_KEY.process.env.REACT_APP_CUSTOMNAME_API_KEY
inside the braces.${}
for the 'search string'.this.state.city
inside the braces.async
to the handleSubmit method label.Restart Node Server whenever you've updated a '.env' file otherwise the key will not be found, resulting in a http 401 error return.
Provide a name to be able to refer to the API Key, like this:
REACT_APP_CUSTOMNAME_API_KEY=pk.keykeykey
=> This results in a variable name that matches the all-caps name above.
Remember to check for these conditions when there are errors:
Similar to the '.env' file but will tell users how to enable their own api key to test or use your code.
REACT_APP_CUSTOMNAME_API_KEY=<your-key-here>
When collecting user input in a form with an in-line onChange event handler:
When a Submit button is clicked on a form, the onSubmitEventHandler function needs to do two things:
Use the Trello board.
Follow the cards for today's assignment.
Complete each Card, item by item, as you do them.
try-catch
An error-handling if-else type statement.
If the code within the try codeblock fails, the catch code block is executed.
To capture the error message in the catch block, pass-in an argument to it and then drill-down with dot notation to get the detail of the error object that you want/need.
Catch-block should not return the entire error to the user, rather a helpful message that means something to the user without giving any code or data secrets away.
Open Netlify.
Open deployment settings.
Add a Site Variable for the API_KEY.
Redeploy required.
Always edit environment variables well before you push a build.