How does API work ?
When we operate on webpage, it will need to get some data from backend.
But, it can’t get data directly from DB(database), instead, need to ask browser to do the favor.
Therefore, there is a communication method between browser and webpage called API.
(Application Programming Interface)
And API can be used to do GET / POST / PATCH / DELETE.
Timing to use each of API method
- GET : When we want some data from DB
- POST : User builds data on webpage site, validated by browser, then send to DB to store.
- PATCH : Similar process to POST, aims to update data in DB.
- DELETE : Remove one specified data in DB.
Difference between client side & server side
Client side: Client can use their unique UUID to access data, validation is not required.
Server side: Administrator have to pass validation, using TOKEN.
Therefor, when we send request from client-side to server-side
if this request is processed by serve-side API
then validation is required, and content is contained inside headers.
Let’s add validation content:
1 | axios.defaults.headers['Authorization'] = `Bearer ${token}`; |
How to use Axios ?
Apply Axios CDN
1 | <script src="https://cdn.jsdelivr.net/npm/axios/dist/axios.min.js"></script> |
Let’s create 4 buttons to represent each method
Attach each DOM, and link with event listener.
1 | document.querySelector('#get').addEventListener('click', getData); |
Declare variable
1 | var uuid = '';//every user has unique one |
GET method
Before we start, one thing we need to know is
The API we use belongs to client side or server side ?
In this example, this GET API is server side, and need to pass validation.
HTTP Request: GET api/{uuid}/admin/ec/products
1 | function getData() { |
POST method
HTTP Request: POST api/{uuid}/admin/ec/product
1 | function postData() { |
PATCH method
When edit one specified data, you need to get ID of that data.HTTP Request: PATCH api/{uuid}/admin/ec/product/{id}
1 | function patchData() { |
DELETE method
When delete one specified data, you need to get ID of that data.HTTP Request: DELETE api/{uuid}/admin/ec/product/{id}
1 | function deleteData() { |