十*七 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 目详情-五一模拟赛详情页
  • ¥15 有了解d3和topogram.js库的吗?有偿请教
  • ¥100 任意维数的K均值聚类
  • ¥15 stamps做sbas-insar,时序沉降图怎么画
  • ¥15 买了个传感器,根据商家发的代码和步骤使用但是代码报错了不会改,有没有人可以看看
  • ¥15 关于#Java#的问题,如何解决?
  • ¥15 加热介质是液体,换热器壳侧导热系数和总的导热系数怎么算
  • ¥100 嵌入式系统基于PIC16F882和热敏电阻的数字温度计
  • ¥15 cmd cl 0x000007b
  • ¥20 BAPI_PR_CHANGE how to add account assignment information for service line