十*七 2022-04-12 17:10 采纳率: 75%
浏览 42
已结题

vue第一次写数据请求,不知道是哪个地方出现问题

img

我封的方法

import axios from "axios";

export default function ajax( url = '', params = { }, type = 'GET' ){
  //1.定义promise对象
  let promise;
  return new Promise( (resolve, reject) =>{
    //2.判断请求方式
    if('GET' === type){
      //2.1.拼接请求字符串
      let paramsStr = '';
      Object.keys(params).forEach(key =>{
        paramsStr += key + '=' + params[key] + '&'
      })
      //2.2.过滤最后的&
      if(paramsStr !== ''){
        paramsStr = paramsStr.substr(0, paramsStr.lastIndexOf('&'))
      }
      //2.3.完整路径
      url += '?' + paramsStr
      //2.4.发送GET请求
      promise = axios.get(url)
    }else if('POST' === type){
      promise = axios.post(url, params)
    }
    //3.返回请求的结果
    promise
      .then( (response) =>{
        resolve(response.data)
      })
      .catch( error =>{
        reject(error)
      })
  })
}

我写的请求

import ajax from './ajax'

//1. 基础路径
const BASE_URL = 'http://10.213.32.101/:9999';


//2. 请求方法

//2.1 请求首页轮播图
export const getHomeSwiper = ()=>ajax( BASE_URL + '/advertising/info/banners' )

HTML页面中的结构


<div class="block" v-if="homeSwiper.length > 0">
        <el-carousel trigger="click" height="600px" ref="carousel" @click.native="linkTo">
          <el-carousel-item v-for="(swiper, index) in homeSwiper" :key="index" >
            <img :src="swiper.imageUrl" class="image">
          </el-carousel-item>
        </el-carousel>
      </div>

页面请求

computed:{
    ...mapState(['homeSwiper'])
  },
  mounted(){
    //1. 请求轮播图数据
    this.$store.dispatch('reqHomeSwiper')
  }

  • 写回答

2条回答 默认 最新

  • zh阿飞 2022-04-14 01:56
    关注

    你这个是和store一起使用的, 你把store代码放出来才能看呐


    还有你这个封装吧,有问题, 如果遇到参数里面有&符号,空格这些特殊字符你就知道了,axios默认就封装好了,可以传params

    axios({url: '', type: '', params: {} )
    
    axios.get(url, {params:{}})
    

    axios.request(config)
    axios.get(url[, config])
    axios.delete(url[, config])
    axios.head(url[, config])
    axios.options(url[, config])
    axios.post(url[, data[, config]])
    axios.put(url[, data[, config]])
    axios.patch(url[, data[, config]])

    img

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 4月29日
  • 已采纳回答 4月21日
  • 创建了问题 4月12日

悬赏问题

  • ¥15 有内推吗,云计算linux运维方向
  • ¥30 sort cuteSV.vcf by bcftools用IGV可视化出现报错
  • ¥100 SOS!对STK中导出的天体图像进行质心提取有没有人做过啊
  • ¥15 python 欧式距离
  • ¥15 运行qteasy报错
  • ¥15 遗传算法解决有工序顺序约束的大规模FJSP问题
  • ¥15 企业消防水炮塔设计方案
  • ¥20 WORKBENCH网格划分
  • ¥60 急招师兄远程解决下载NPCAP的BUG!
  • ¥15 关于#51单片机#的问题:51单片机LM1602的数据只能显示一个字符,在使用矩形键盘送数据的时候不能显示出来而是在显示初始位置上,达不到密码锁的效果