Home  >  Article  >  Web Front-end  >  vue implements restful address

vue implements restful address

WBOY
WBOYOriginal
2023-05-27 18:00:38602browse

Vue is a front-end framework. Its emergence makes front-end development simpler and more efficient. During development with Vue, it is very common to use Restful API. Restful API is an API based on REST (Representational State Transfer), which is a design style, usually based on the HTTP protocol, for creating and accessing web services. In this article, we will explore how Vue implements RESTful addresses.

1. Understanding RESTful API

Restful API is an architectural style that is based on Web and HTTP protocols. It is a style that emphasizes simplicity, scalability, maintainability and readability. Sexual API. Its rules are relatively simple: use the specific methods of the HTTP protocol (GET, POST, PUT, DELETE, etc.) to implement operations on server resources.

For example, the GET method means obtaining resource data from the server, the POST method means creating new resource data on the server, the PUT method means updating resource data on the server, and the DELETE method means deleting resource data on the server, etc.

Restful API uses JSON format to transmit data during data interaction. JSON (JavaScript Object Notation) is a lightweight data exchange format and a subset of JavaScript native objects. It has good readability, parsability and semantics, making it ideal for mobile and web applications.

2. Use Axios in Vue for HTTP requests

Vue uses Axios as the HTTP request tool. Axios is a popular Promise-based HTTP client that can easily handle RESTful API requests. . First, we need to install Axios via npm:

npm install axios

Then, we will use Axios in the Vue component to send a GET request to get the data of a RESTful API:

<template>
  <div>
    <ul>
      <li v-for="item in items" :key="item.id">
        {{ item.title }}
      </li>
    </ul>
  </div>
</template>

<script>
import axios from 'axios';

export default {
  data() {
    return {
      items: []
    };
  },
  created() {
    axios
      .get(`https://jsonplaceholder.typicode.com/todos`)
      .then(response => {
        this.items = response.data;
      })
      .catch(error => {
        console.log(error);
      });
  }
};
</script>

In this example, we You can see that this component gets the data and binds it to a list. We first use the import statement to import Axios, and then use the axios.get() method in the component to send a GET request. After the request is successful, we assign the response data to the items data attribute of the component.

3. Implement RESTful address

Restful address usually refers to the address that contains resources and operation types in the URL, for example:

GET /api/posts 获取所有文章
POST /api/posts 新增文章
PUT /api/posts/1 更新ID为1的文章
DELETE /api/posts/1 删除ID为1的文章

Restful address is actually the core of a RESTful API , because it combines resource and operation types, making the structure of the API clearer and easier to understand. To implement Restful addresses in Vue, we need to specify the request method and request address in the Axios request. Next is an example of using Axios and Vue to implement a Restful address:

<template>
  <div>
    <ul>
      <li v-for="item in items" :key="item.id">
        {{ item.title }}
      </li>
    </ul>
  </div>
</template>

<script>
import axios from 'axios';

export default {
  data() {
    return {
      items: []
    };
  },
  created() {
    axios
      .get(`/api/posts`)
      .then(response => {
        this.items = response.data;
      })
      .catch(error => {
        console.log(error);
      });
  },
  methods: {
    createItem() {
      axios
        .post(`/api/posts`, {
          title: 'New Post',
          body: 'This is a new post'
        })
        .then(response => {
          this.items.push(response.data);
        })
        .catch(error => {
          console.log(error);
        });
    },
    updateItem(item) {
      axios
        .put(`/api/posts/${item.id}`, {
          title: 'Updated Post',
          body: 'This is an updated post'
        })
        .then(response => {
          this.items.splice(this.items.indexOf(item), 1, response.data);
        })
        .catch(error => {
          console.log(error);
        });
    },
    deleteItem(item) {
      axios
        .delete(`/api/posts/${item.id}`)
        .then(() => {
          this.items.splice(this.items.indexOf(item), 1);
        })
        .catch(error => {
          console.log(error);
        });
    }
  }
};
</script>

In this example, we create a Vue component to obtain and operate the RESTful API. First, we use the axios.get() method to obtain all articles, and then assign the response data to the items data attribute of the component after successful acquisition. Next, we define a method for creating, updating, and deleting resources: createItem(), updateItem(), and deleteItem().

Among these methods, we use the axios.post(), axios.put() and axios.delete() methods respectively Specify the POST, PUT, and DELETE request methods, and specify the resource ID in the request address. After the request is successful, we update the response data to the items data attribute of the component.

4. Summary

In this article, we implemented HTTP requests to Restful API by using Axios and Vue. We learned about the principles of Restful API and how to implement RESTful addresses in Vue, and how to use Axios to send HTTP requests to obtain and operate Web API resources. If you are developing a web application, try using Vue and Axios to optimize your Restful API requests.

The above is the detailed content of vue implements restful address. For more information, please follow other related articles on the PHP Chinese website!

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn