vue 请求后端数据的示例代码

在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安装与应用【附带图片讲解】

到此这篇关于vue请求后端数据的文章就介绍到这了,更多相关vue请求后端数据内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • Vue请求后端接口导出excel表格方式

    目录 vue请求后端接口导出excel 调用后端接口导出excel无效果,直接访问后端url可以 controller层代码 serviceImpl代码 导出模板路径 工具箱代码 vue前端写法 vue请求后端接口导出excel 项目中遇到一个需求,用户下载文件,会从后端那里请求接口获得数据并下载导出excel表格 后端小哥给我返回的是二进制数据流,需要前端自己去处理这些数据 如下图,请求接口返回的数据都是乱码 这里我们可以在axios的请求里添加,这样返回的二进制数据就会被读取为Blob的数据

  • Vue简单封装axios之解决post请求后端接收不到参数问题

    1.在src/下新建api文件夹,api/下新建index.js和public.js 在public.js中: import axios from 'axios'; import qs from 'qs' import router from '../router' import { MessageBox} from 'mint-ui' // 注意点,按照以下写 var instance = axios.create(); instance.defaults.timeout = 10000; i

  • vue element自定义表单验证请求后端接口验证

    做vue项目的时候遇到了一个需求,在验证某个表单项时不仅需要是必填项而且要去通过接口校验是否有重复值. template <el-form-item label="账户" prop="userid"> <el-input v-model="addForm.userid"></el-input> </el-form-item> 引入接口 import { checkUseridRepeat } fro

  • vue 请求后端数据的示例代码

    在vue中,我们如何通过请求接口来访问后端的数据呢?在这里简单总结了一个小示例: 主要问题:如果不封装的话,在每次请求的时候都要书写一遍下面的代码,造成代码冗余. 1.在src目录下创建一个utils文件夹,然后在里面创建一个js文件.这里我创建了一个request.js文件. /*引入axios*/ import axios from 'axios' const request = axios.create({ baseURL: 'http://localhost:8280/user', //

  • vue 运用mock数据的示例代码

    本文介绍了vue 运用mock数据的示例代码,分享给大家,具体如下: 初始化你的项目 话不用啰嗦,首先初始化你的项目,最简单的就是使用vue-cli啦 vue init webpack 引入mock.js 安装 mockjs npm install --save-dev mockjs 引入到Vue原型上,方便使用 import mockjs from 'mockjs' Vue.prototype.$mock = Vue.$mock = mockjs.mock 以上引入到Vue原型上,可以使用 t

  • vue 请求后台数据的实例代码

    需要引用vue-resource 安装请参考https://github.com/pagekit/vue-resource官方文档 在入口函数中加入 import VueResource from 'vue-resource' Vue.use(VueResource); 在package.json文件中加入 "dependencies": { "vue": "^2.2.6", "vue-resource":"^1.2

  • FastApi+Vue+LayUI实现前后端分离的示例代码

    目录 前言 项目设计 后端 前端 运行项目 Q&A 前言 在前面的Api开发中,我们使用FastApi已经可以很好的实现.但是实际使用中,我们通常建议前后端项目分离.今天我们就使用FastApi+Vue+LayUI做一个前后端分离的Demo. 项目设计 后端 后端我们采用FastApi在新的test视图中,定义一个路由,并将其注册到app中,并且在test视图中定义一个接口,实现模拟从数据库读取数据供前端调用渲染. 代码 test.py from fastapi import FastAPI,D

  • webpack+vuex+axios 跨域请求数据的示例代码

    本文介绍了webpack+vuex+axios 跨域请求数据的示例代码,分享给大家,具体如下: 使用vue-li 构建 webpack项目,修改bulid/config/index.js文件 dev: { env: require('./dev.env'), port: process.env.PORT || 8080, autoOpenBrowser: true, assetsSubDirectory: 'static', assetsPublicPath: '/', proxyTable:

  • 使用Vue调取接口,并渲染数据的示例代码

    刚接触vue.js框架的时候,很伤脑筋.今天整理一下post/get两种方式,简单的调取数据库数据,并进行渲染,希望帮助大家! 首先,在HTML页面引入: //引入vue.js文件 <script src="https://cdn.staticfile.org/vue/2.4.2/vue.min.js"></script> 引入vue-resource.min.js文件,就可以引入接口方法了 <script src="https://cdn.st

  • 详解vue与后端数据交互(ajax):vue-resource

    本人对vue与后端数据交互不是很懂,搜索了很多关于vue与后端数据交互介绍,下面我来记录一下,有需要了解的朋友可参考.希望此文章对各位有所帮助. 必须引入一个库:vue-resource 1.获取普通文本数据 比如:a.txt: welcomet to vue!!! <!DOCTYPE html> <html> <head> <title></title> <meta charset="utf-8"> <sc

  • vue实现图片滚动的示例代码(类似走马灯效果)

    上次写了一个简单的图片轮播,这个相当于在上面的一些改进.这个组件除了可以进行图片滚动外,也可以嵌入任何内容的标签进行滚动,里面用了slot进行封装. 父: <template> <div id="app"> <er-carousel-index :typeNumber=2 :pageNumber=3 :timeSpace=2 :duration=2 :isOrNotCircle="true" url="/src/js/inde

  • 如何理解Vue前后端数据交互与显示

    一.技术概述 将后端所计算的数据呈现在前端页面的相应位置并根据用户点击操作改变相应的数据和界面,再传值给后端.该技术是Web开发必备,是前后端交互的纽带.难点在于获取后端数据并且防止数据联动. 二.技术详述 1. 从接口获取后端数据 (1) 仔细查看后端所传数据的类型.主要是区分数组和单个数据.查看后端的请求方式,区分post或者get. (2) 首先,在data中return一个xxxData:[]数组或一个变量xxxData:<类型>来接收后端传来的数据. (3) 在方法中定义一个请求函数

  • django+vue实现注册登录的示例代码

    注册 前台利用vue中的axios进行传值,将获取到的账号密码以form表单的形式发送给后台. form表单的作用就是采集数据,也就是在前台页面中获取用户输入的值.numberValidateForm:前台定义的表单 $axios使用时需要在main.js中全局注册,.then代表成功后进行的操作,.catch代表失败后进行的操作 submitForm(formName) { let data = new FormData() data.append('username',this.number

随机推荐