• axios的详解 axios拦截器 创建实例 全局配置 封装和使用 axios的使用


    axios的使用方法

    axios({

    url:"http://",

    method:'get/post/put/delete'默认是get

    }).then(res=>console.log(res))

    axios({

    url:"http://",

    专门针对get请求的参数拼接(?type=pop&page=1)

    params:{

    type:'pop',

    page:'1'

    }

    method:'get/post/put/delete'默认是get

    })

    也可以是axios.get()    .post()    .delete()    .put()
    axios的并发请求

    axios.all([

    axios({

    url:"https://www.baidu.com"

    }),

    axios({

    url:"https://www.baidu.com",

    params:{

    type:'pop',

    page:'2'

    }

    }),

    ]).then(results=>{

    console.log(result[0])

    })/////

    then(axios.spread(result1,result2)=>{

    console.log(result1)///

    })

    全局配置

    axios.defaults.baseURL='123.207.32.32.8000'

    axios.defaults.headers.post['Content-Type']='application/x-www-form-urlencoded'

    axios.defaults.timeout=5000

    创建实例

    每个实例都可以有自己的配置,相互不干扰

    const instance=axios.create({

    baseURL:'https://www.baidu.com',

    timeout:5000,

    headers:{}

    })

    instance({

    url:'/home/data',

    params:{

    type:'pop',

    page:'2'

    }

    }).then(res=>console.log(res))

    封装网络模块

    request.js

    axios使用promise()对网络请求进行封装

    // request({
    // url: '/home/multidata'
    // }).then(res => { }).catch(err => { })
     
    // instance本身就是一个promise()
    export function request(config) {
    // 创建实例
    const instance = axios.create({
    baseURL: 'http://123.207.32.32.8000',
    timeout: 5000
    })
    return instance(config)
    //instance本身就是一个promise()
    }
     
    axios网络的封装
    // 回调函数的方案
    request({
    url: '/home/multidata'
    }, res => console.log(res), err => {
    console.log(err);
    })
    export function request(config, success, failure) {
    // 创建实例
    const instance = axios.create({
    baseURL: 'http://123.207.32.32.8000',
    timeout: 5000
    })
    instance(config).then(
    res => {
    console.log(res);
    success(res)
    }
    ).catch(err => {
    console.log(err);
    failure(err)
    })
    }
     
    // axios请求拦截
    instance.interceptors.request.use(config=>{
    console.log(config);
    //**** */必须把config返回出去,
    // 请求拦截的作用
    // 1、配置config的一些信息不符合服务器的要求
    // 2、每次网络请求希望显示一个请求图标
    // 3、某些网络请求必须带一些特殊信息(token)
    return config
    },err=>{
    console.log(err);
    })
    // axios响应拦截
    instance.interceptors.response.use(res=>{
    console.log(res);
    // 拦截器最重要的是必须return res 把结果给返回出去
    return res.data
    },err=>{
    console.log(err);
    })
     

    正常情况下在data里面都有做了定义

    在函数里面进行赋值

    这时候你运行时会发现,数据可以请求到,但是会报错 TypeError: Cannot set property 'listgroup' of undefined 

    主要原因是:

    在 then的内部不能使用Vue的实例化的this, 因为在内部 this 没有被绑定。
    可以看下 Stackoverflow 的解释:

    解决办法:

    1、用ES6箭头函数,箭头方法可以和父方法共享变量 

     2、在请求axios外面定义一下 var that=this 

     https://www.apiopen.top/api.html#4c502eec73ce429fb1c4a7f519360d24

    dev: `webpack-dev-server --inline --progress --config build/webpack.dev.conf.js` vue启动报错解决

    这是因为webpack-dev-server版本和vue版本不一样,需要将webpack-dev-server卸载了,安装对应版本

    查看vue版本是 vue -V

    注意:V是大写

    卸载npm uninstall webpack-dev-server,在安装这个npm i webpack-dev-server@2.9.7,我的可以正常启动了。

  • 相关阅读:
    note 11 字典
    note10 元组
    hibernate环境搭建及操作
    JAVA中解决Filter过滤掉css,js,图片文件等问题
    过滤器
    MySQL存储过程(转)
    用java调用oracle存储过程总结(转)
    Oracle分页查询语句的写法(转)
    数据访问类的封装
    事务的特性及事务的隔离级别(转)
  • 原文地址:https://www.cnblogs.com/bgml/p/10745153.html
Copyright © 2020-2023  润新知