Home  >  Article  >  Web Front-end  >  How to use Vue and Axios to request and update page-level data

How to use Vue and Axios to request and update page-level data

WBOY
WBOYOriginal
2023-07-17 17:34:441128browse

How to use Vue and Axios to request and update page-level data

Introduction:
In today's front-end development, data request and update are very common and important operations. As a popular front-end framework, Vue.js provides a data-driven way of thinking. At the same time, combined with Axios, an excellent HTTP library, it can easily implement page-level data requests and updates. This article will introduce in detail how to use Vue and Axios to request and update page-level data in the Vue project, and provide some related code examples.

  1. Installing and introducing Vue and Axios
    First, make sure that Vue and Axios have been installed in your project. If it is not installed, you can install it with the following command.

    npm install vue axios

    Next, where Vue and Axios need to be used, introduce them through the following code.

    import Vue from 'vue'
    import axios from 'axios'
    
    Vue.prototype.$axios = axios
  2. Send a request to obtain data
    Generally speaking, we will send a request in the life cycle hook function of the Vue component to obtain data and display it. The following is an example that demonstrates how to send a GET request to obtain data in a Vue component.

    export default {
      data() {
     return {
       users: []
     }
      },
      mounted() {
     this.$axios.get('/api/users')
       .then(response => {
         this.users = response.data
       })
       .catch(error => {
         console.error(error)
       })
      }
    }

    In the above code, the mounted life cycle hook function will be automatically called after the component is mounted, and then send a GET request to the /api/users interface, and assign the returned data to the data of the component. users attribute.

  3. Update data
    Once the data is obtained, we can operate and display it in the Vue component. Below is an example showing how to update data in a Vue component.

    export default {
      data() {
     return {
       users: []
     }
      },
      methods: {
     updateUser(id, newName) {
       this.$axios.put(`/api/users/${id}`, { name: newName })
         .then(response => {
           // 更新成功,更新对应用户的name
           const updatedUser = response.data
           const index = this.users.findIndex(user => user.id === updatedUser.id)
           if (index !== -1) {
             this.$set(this.users, index, updatedUser)
           }
         })
         .catch(error => {
           console.error(error)
         })
     }
      }
    }

    In the above code, the updateUser method will receive a user id and new user name as parameters, and send a PUT request to the corresponding interface. When the request is successful, we can update the user's name attribute in the response callback function and ensure responsive updates through Vue's $set method.

  4. Supplementary: Sending POST requests and deleting data
    In addition to GET and PUT requests, we can also send POST requests to create new data, and send DELETE requests to delete data. Below are two examples demonstrating how to send POST and DELETE requests.

    export default {
      methods: {
     createUser(name) {
       this.$axios.post('/api/users', { name: name })
         .then(response => {
           // 创建成功,将新用户添加到users数组中
           const newUser = response.data
           this.users.push(newUser)
         })
         .catch(error => {
           console.error(error)
         })
     },
     deleteUser(id) {
       this.$axios.delete(`/api/users/${id}`)
         .then(() => {
           // 删除成功,从users数组中移除对应用户
           const index = this.users.findIndex(user => user.id === id)
           if (index !== -1) {
             this.users.splice(index, 1)
           }
         })
         .catch(error => {
           console.error(error)
         })
     }
      }
    }

    In the above code, the createUser method will receive a username as a parameter and send a POST request to the /api/users interface to create a new user. When the request is successful, we can add the new user to the users array in the response callback function. The deleteUser method receives a user id as a parameter and sends a DELETE request to the corresponding interface to delete the corresponding user. When the request is successful, we can remove the corresponding user from the users array in the response callback function.

Summary:
Through the combination of Vue and Axios, we can easily implement page-level data requests and updates in the Vue project. Through the above code examples, you can better understand how to use Vue and Axios to send GET, POST, PUT and DELETE requests, and operate and update the returned data. I hope this article can help you understand and use Vue and Axios to handle data requests in your project.

The above is the detailed content of How to use Vue and Axios to request and update page-level data. 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