search
HomeWeb Front-endVue.jsHow 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

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
Netflix: Unveiling Its Frontend FrameworksNetflix: Unveiling Its Frontend FrameworksMay 04, 2025 am 12:16 AM

Netflix uses React as its front-end framework. 1.React's component development and virtual DOM mechanism improve performance and development efficiency. 2. Use Webpack and Babel to optimize code construction and deployment. 3. Use code segmentation, server-side rendering and caching strategies for performance optimization.

Frontend Development with Vue.js: Advantages and TechniquesFrontend Development with Vue.js: Advantages and TechniquesMay 03, 2025 am 12:02 AM

Reasons for Vue.js' popularity include simplicity and easy learning, flexibility and high performance. 1) Its progressive framework design is suitable for beginners to learn step by step. 2) Component-based development improves code maintainability and team collaboration efficiency. 3) Responsive systems and virtual DOM improve rendering performance.

Vue.js vs. React: Ease of Use and Learning CurveVue.js vs. React: Ease of Use and Learning CurveMay 02, 2025 am 12:13 AM

Vue.js is easier to use and has a smooth learning curve, which is suitable for beginners; React has a steeper learning curve, but has strong flexibility, which is suitable for experienced developers. 1.Vue.js is easy to get started with through simple data binding and progressive design. 2.React requires understanding of virtual DOM and JSX, but provides higher flexibility and performance advantages.

Vue.js vs. React: Which Framework is Right for You?Vue.js vs. React: Which Framework is Right for You?May 01, 2025 am 12:21 AM

Vue.js is suitable for fast development and small projects, while React is more suitable for large and complex projects. 1.Vue.js is simple and easy to learn, suitable for rapid development and small projects. 2.React is powerful and suitable for large and complex projects. 3. The progressive features of Vue.js are suitable for gradually introducing functions. 4. React's componentized and virtual DOM performs well when dealing with complex UI and data-intensive applications.

Vue.js vs. React: A Comparative Analysis of JavaScript FrameworksVue.js vs. React: A Comparative Analysis of JavaScript FrameworksApr 30, 2025 am 12:10 AM

Vue.js and React each have their own advantages and disadvantages. When choosing, you need to comprehensively consider team skills, project size and performance requirements. 1) Vue.js is suitable for fast development and small projects, with a low learning curve, but deep nested objects can cause performance problems. 2) React is suitable for large and complex applications, with a rich ecosystem, but frequent updates may lead to performance bottlenecks.

Vue.js vs. React: Use Cases and ApplicationsVue.js vs. React: Use Cases and ApplicationsApr 29, 2025 am 12:36 AM

Vue.js is suitable for small to medium-sized projects, while React is suitable for large projects and complex application scenarios. 1) Vue.js is easy to use and is suitable for rapid prototyping and small applications. 2) React has more advantages in handling complex state management and performance optimization, and is suitable for large projects.

Vue.js vs. React: Comparing Performance and EfficiencyVue.js vs. React: Comparing Performance and EfficiencyApr 28, 2025 am 12:12 AM

Vue.js and React each have their own advantages: Vue.js is suitable for small applications and rapid development, while React is suitable for large applications and complex state management. 1.Vue.js realizes automatic update through a responsive system, suitable for small applications. 2.React uses virtual DOM and diff algorithms, which are suitable for large and complex applications. When selecting a framework, you need to consider project requirements and team technology stack.

Vue.js vs. React: Community, Ecosystem, and SupportVue.js vs. React: Community, Ecosystem, and SupportApr 27, 2025 am 12:24 AM

Vue.js and React each have their own advantages, and the choice should be based on project requirements and team technology stack. 1. Vue.js is community-friendly, providing rich learning resources, and the ecosystem includes official tools such as VueRouter, which are supported by the official team and the community. 2. The React community is biased towards enterprise applications, with a strong ecosystem, and supports provided by Facebook and its community, and has frequent updates.

See all articles

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

Video Face Swap

Video Face Swap

Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Tools

SublimeText3 Linux new version

SublimeText3 Linux new version

SublimeText3 Linux latest version

SAP NetWeaver Server Adapter for Eclipse

SAP NetWeaver Server Adapter for Eclipse

Integrate Eclipse with SAP NetWeaver application server.

SublimeText3 English version

SublimeText3 English version

Recommended: Win version, supports code prompts!

PhpStorm Mac version

PhpStorm Mac version

The latest (2018.2.1) professional PHP integrated development tool

VSCode Windows 64-bit Download

VSCode Windows 64-bit Download

A free and powerful IDE editor launched by Microsoft