vue-axios安装及代理服务器配置及发起网络请求例子
首页->学习资料->web前端->vue教程->vue2 关键词: 发布时间:2024-01-04 16:26:51 浏览次数:106

vue-axios安装及代理服务器配置及发起网络请求例子,实现搜索及列表展示的功能,包括loading,错误提示,欢迎

image.png


先要在vue.config.js中配置代理

const { defineConfig } = require('@vue/cli-service')
module.exports = defineConfig({
  transpileDependencies: true,
  lintOnSave:true,//关闭语法检查
  //代理配置:准确的说应该是代理服务器转发规则
  devServer:{
    /**
     * 单代理设置
     * 请求地址填:http://localhost:8080/about
     * 转为:https://api.hu-rong.com/about
     */
    proxy:'https://api.hu-rong.com'
    //多个代理
    // proxy:{
    //   /**
    //    *当请求前缀为api时走代理,如请求地址为:http://localhost:8080/demo/about则走此处代理
    //    *最终请求的真实地址为:https://api.hu-rong.com/about
    //    */
    //   '/demo':{
    //     target:'https://api.hu-rong.com',
    //     pathRewrite:{'^/demo':''},//地址重写,将url中的/demo替换为空,则请求的真实地址为https://api.hu-rong.com/about
    //     //ws:true,//用于支持websocket,默认为true
    //     //changeOrigin:true,//请求控制请求头中的host值,默认为true;false时为代理的地址,true为真实服务器地址
    //   },
    // }
  }
})
<template>
  <div class="app">
    p96-100:vue-axios安装及代理服务器配置<br/>
    安装:npm i axios<br/>
    vue-cli中用代理服务器实现跨域原理:当我们启动vue-cli后,访问localhost:8080展示首页<br/>
    本例中点击按钮发送http请求访问一个接口如:(http://api.hu-rong.com/about)<br/>
    如果用以前的ajax请求,则我们请求时的接口地址就是上面这个接口的地址,这样就有跨域的问题,导致请求不成功<br/>
    vue-cli中配置了代理后,启动了一个代理服务器,它的端口也是8080,所以应该将请求地址设置为<br/>
    http://localhost:8080/about<br/>
    而不是<br/>
    http://api.hu-rong.com/about<br/>
    当点击按钮触发请求时,他先经过http://localhost:8080/代理服务器,<br/>
    通过规则(在vue.config.js中配置)将对应请求地址转为真实的接口地址http://api.hu-rong.com<br/>
    因为它底层走的不是http协议,所以不存在跨域问题
    <hr/>
    <input readonly v-model="id" type="text" placeholder="输入相册id">
    <button @click="search">搜索相册</button>
    <hr/>
    <!--相册列表-->
    <div v-show="photos.length" class="photo-list" v-for="p in photos" :id="p.id">
      <img :src="p.image" border="0" width="120px" height="80px"/>
    </div>
    <!--欢迎-->
    <h3 v-show="isFirst">欢迎!</h3>
    <!--loading-->
    <h3 v-show="isLoading">加载中...</h3>
    <!--error-->
    <h3 v-show="error">{{ error }}</h3>

    <div class="clear-float"></div>
  </div>
</template>

<script>
//引入axios
import axios from 'axios'

export default {
  name: 'App',
  data() {
    return {
      id: 1,//相册id
      isFirst: true,//是否初次展示
      isLoading: false,//是否加载中
      error: '',//错误信息
      photos: {},
    }
  },
  methods: {
    search() {
      //发请求前
      this.isFirst = false
      this.isLoading = true
      this.photos = {}
      //http://localhost:8080是代理服务器的地址,发请求后通过它转发到真实接口,真实接口请求成功后,代理服务器将结果返回
      axios.get('http://localhost:8080/photo/' + this.id).then(
          response => {
            console.log('请求成功', response.data)
            this.isLoading = false
            this.photos = response.data.images
          },
          error => {
            this.isLoading = false
            this.error = '请求失败,错误信息:' + error
            console.log('请求失败')
          }
      )
    }
  },
  mounted() {
    this.search()
  }
}
</script>

<style scoped>
.photo-list {
  text-align: center;
  margin: 0 auto;
  padding: 10px;
  float: left;
}
</style>


赞:(0)
踩:(0)
相关文章
初识vue
数据绑定:第一个vue例子
vue模板语法
vue数据绑定
el与data的两种写法/延迟挂载
vue数据代理-Object.definePropert
vue事件及事件修饰符prevent/stop/
vue计算属性computed
vue(深度)监视属性watch
vue绑定样式:class,:style
热门文章
win7中将文件拷贝到虚拟机linux下
phpexcel设置行高及列宽,背景颜色,
rabbitmq无法启动
intellij idea不显示git push按钮
php7中使用mongodb的aggregate进行
centos7.4 64位下swoole安装及配置
laravel页面静态化的方法
navicate连接mycat报1184错误
单点登录sso原理及php实现方式及de
devops-jenkins容器为pending状态
好评文章
phpexcel设置行高及列宽,背景颜色,
php7中使用mongodb的aggregate进行
intellij idea打开文件所在文件夹
windows下使用MongoDB Compass Com
win7中将文件拷贝到虚拟机linux下
laravel 中悲观锁 & 乐观锁的使用
单点登录sso原理及php实现方式及de
navicate连接mycat报1184错误
rabbitmq无法启动
laravel整合dingo/api方法步骤:jwt
标签
rabbitmq mysql备份 elasticsearch golang swoole
我的项目
【github】www.github.com/hurong241
【码云】gitee.com/hu_rong/projects
【docker hub】hub.docker.com/repositories/hurong241
【packagist】packagist.org/users/hurong241/packages
站点信息
建站时间:2011年
文章数:608篇
浏览数:952674
粤ICP备18028092号-1  微信:hurong241