锋盈数科-知识库 Logo
首页
软件开发
计算机基础
Hello Halo
新手必读
关于本知识库
登录 →
锋盈数科-知识库 Logo
首页 软件开发 计算机基础 Hello Halo 新手必读 关于本知识库
登录
  1. 首页
  2. 软件开发
  3. vue如何请求后端数据

vue如何请求后端数据

0
  • 软件开发
  • 发布于 2024-08-19
  • 12 次阅读
黄健
黄健

在vue中,我们如何通过请求接口来访问后端的数据呢?在这里简单总结了一个小示例:

主要问题:如果不封装的话,在每次请求的时候都要书写一遍下面的代码,造成代码冗余。

1、在src目录下创建一个utils文件夹,然后在里面创建一个js文件。这里我创建了一个request.js文件。

/*引入axios*/
import axios from 'axios'
const request = axios.create({
    baseURL: 'http://localhost:8280/user', // 基础路径,将统一的部分全部封装
    withCredentials: true // 表示请求可以携带cookie
})
//前端采用export.default,在写后端代码时用module.export
export default request

在app.vue中进行测试:

<script>
import request from './utils/request'

export default {
  created() {
    request({
      method:'GET',
      url:'/products',
      params:{test:'111',hello:'world'},
    })
  },
}
</script>

2、在src文件夹下创建一个api文件夹,根据不同的功能进行分组,分别写不同的接口。这里我创建了一个product.js。

import request from '../utils/request';

export function getList(params={}) {
    return request({
        methods:'GET',
        url:'/products',
        params,
    })
}

export function getProduct(id) {
    return request({
        methods:'GET',
        url:'/products/${id}',
    })
}
export function update(id,data) {
    return request({
        methods:'PUT',
        url:'/products/${id}',
        data,
    })
}

3、在api文件夹下创建index.js

import products from './products';

export default{
    products,
}

4、在main.js中引入api文件夹下的index。

import api from './api/index.js';

Vue.prototype.$api = api

5、此时通过接口获取后端数据的方式就变成了如下格式:

getProducts(){
    this.$api.products.getList(this.query).then((response)=>{
        this.products = response.data.data
        this.total = response.data.total
    })
}

6、列表展示案例:

main.js中添加代码

import Vue from 'vue'
import App from './App'
import router from './router'
import axios from 'axios';

//Vue.prototype.$http=axios;//修改内部的$http为axios  $http.get("") .post()

Vue.config.productionTip = false

/* eslint-disable no-new */
new Vue({
  el: '#app',
  router,
  components: { App },
  template: '<App/>',
  render:h => h(App),
  beforeCreate() {
    //安装全局事件总线,$bus就是当前应用的vm
    Vue.prototype.$bus = this
  },

})

App.vue中添加代码

<template>
  <div>
    <Search/>
    <List/>
  </div>
</template>

<script>
import List from "./components/List";
import Search from "./components/Search";
export default {
  name: 'App',
  components: {Search, List},
}
</script>

<style>

</style>

router下的index.js中的代码

import Vue from 'vue'
import Router from 'vue-router'

Vue.use(Router)

export default new Router({
  routes: [

  ]
})

list.vue代码示例:

<template>
  <div class="row">
    <!--展示用户数据-->
    <div class="card" v-show="info.users.length" v-for="user in info.users" :key="user.login">
      <a :href="user.html_url" target="_blank">
        <img :src="user.avatar_url" style="width: 100px"/>
      </a>
      <p class="card-text">{
  {user.login}}</p>
    </div>
    <!--展示欢迎词-->
    <h1 v-show="info.isFirst">欢迎使用</h1>
    <!--展示加载中-->
    <h1 v-show="info.isLoading">加载中....</h1>
    <!--展示错误信息-->
    <h1 v-show="info.errMsg">{
  {info.errMsg}}</h1>
  </div>
</template>

<script>
export default {
  name: "List",
  data(){
    return{
     info:{
       isFirst:true,//是否是初次展示
       isLoading:false,//是否处于加载中
       errMsg:'',
       users:[],
     }
    }
  },
  //使用全局事件总线在两个组件之间传递数据
  //接收数据:list组件想接收数据,则要在list组件中给$bus绑定自定义事件,事件的回调留在list组件自身。
  mounted() {
    this.$bus.$on('updateListDate',(dataObj)=>{
      console.log(dataObj)
      this.info = {...this.info,...dataObj};
      /*this.isFirst = isFirst
      this.isLoading = isLoading
      this.errMsg = errMsg
      this.users = users*/
    })
  },
}
</script>

<style scoped>

</style>

search.vue代码示例:

<template>
  <section class="jumbotron">
    <h3 class="jumbotron-heading"> search gitHub Users</h3>
    <div>
      <input type="text" placeholder="enter the name you search" v-model="keyWord"/>&nbsp;
      <button @click="searchUsers" >Search</button>
    </div>
  </section>
</template>
<script>
import axios from 'axios';
export default {
  name: "Search",
  data(){
    return{
      keyWord:''
    }
  },
  methods:{
    searchUsers(){
      //请求前更新list里面的数据
      this.$bus.$emit('updateListDate',{isFirst:false,isLoading:true,errMsg:'',users:[]})
      axios.get(`https://api.github.com/search/users?q=${this.keyWord}`).then(
        res =>{
          console.log("请求成功")
          //提供数据:search组件要给list组件传递数据,就要触发list组件中的自定义事件并携带要传递的数据
          //请求成功后更新list里面的数据
          this.$bus.$emit("updateListDate",{isLoading:false,errMsg:'',users:res.data.items})
        },
        error =>{
          console.log("请求成功",error.message)
          //请求失败后更新list里面的数据
          this.$bus.$emit("updateListDate",{isLoading:false,errMsg:error.message,users:[]})
        }
      )
    }
  },
}
</script>

<style scoped>

</style>

注:Vue全局事件总线$bus安装与应用【附带图片讲解】可以参考下面的地址:

Vue全局事件总线bus安装与应用【附带图片讲解】_codnan的博客-CSDN博客_安装事件总线Vue全局事件总线bus安装与应用【附带图片讲解】https://blog.csdn.net/annans/article/details/124658904

原文链接: https://blog.csdn.net/friggly/article/details/125533080

标签: #VUE 61 #软件开发 1171
相关文章

万字:支付“核心系统”详解 2024-11-02 15:33

专栏作者:隐墨星辰 \| 主编:陈天宇宙 这篇文章也尝试化繁为简,探寻支付系统的本质,讲清楚在线支付系统最核心的一些概念和设计理念。 虽然支付行业已经过了风头最劲的时光,但跨境支付仍然在蓬勃发展,每年依然有很多新人进入这个行业,这篇文章尝试为这些刚入行的新人提供一点帮助。 文章只介绍一些支付行业十几

资深支付架构师视角:实战从问题定义到代码落地的完整套路 2024-11-02 15:33

前言 今天从一个实际案例入手,介绍站在架构师的角度,如何识别并定义问题,提炼需求,技术方案选型,再到详细设计,最后利用AI的能力协助写出核心的代码,验证与调优。 解决问题存在一定的模式,也可以称之为框架,总结出自己的思考和解题框架,以后再碰到同类型的问题就可以如庖丁解牛一样容易。 很多年前,我写代码

Spring 实现 3 种异步接口 2024-10-18 09:07

大家好,我是苏三~ 如何处理比较耗时的接口? 这题我熟,直接上异步接口,使用 Callable、WebAsyncTask 和 DeferredResult、CompletableFuture等均可实现。 但这些方法有局限性,处理结果仅返回单个值。在某些场景下,如果需要接口异步处理的同时,还持续不断地

重学SpringBoot3-集成Redis(五)之布隆过滤器 2024-10-08 11:24

更多SpringBoot3内容请关注我的专栏:《SpringBoot3》 期待您的点赞👍收藏⭐评论✍ 重学SpringBoot3-集成Redis(五)之布隆过滤器 1. 什么是布隆过滤器? * 基本概念 适用场景 2. 使用 Redis 实现布隆过滤器 * 项目依赖 Redis 配置

设计模式第16讲——迭代器模式(Iterator) 2024-10-08 11:24

一、什么是迭代器模式 迭代器模式是一种行为型设计模式,它提供了一种统一的方式来访问集合对象中的元素,而不是暴露集合内部的表示方式。简单地说,就是将遍历集合的责任封装到一个单独的对象中,我们可以按照特定的方式访问集合中的元素。 二、角色组成 抽象迭代器(Iterator):定义了遍历聚合对象所需的方法

vue2路由和vue3路由区别及原理 2024-10-08 11:24

一、Vue2 与 Vue3 路由的区别 1. 创建路由实例方式的不同 Vue 2 中,通过 Vue.use() 注册路由插件,并通过 new VueRouter() 来创建路由实例。 import Vue from 'vue';import VueRouter from 'vue-router';i

目录

IT 外包服务商

  • 意见投递
  • zyf6619

软件开发应用

主菜单

  • 首页
  • 软件开发
  • 计算机基础
  • Hello Halo
  • 新手必读
  • 关于本知识库
Copyright © 2024 your company All Rights Reserved. Powered by Halo.