异步中的问题

<script>
import axios from 'axios';
axios.defaults.baseURL='http://........'//正确的地址
export default {
    methods:{
        getBook(){
           axios({
               method:"GET",
               url:'/api/getbooks',
           }).then(function(e){
               this.books=[...e.data.data]
           }).catch(function(e){
               console.log(e);
           })
        },
    },
    data(){
        return{
            books:[],
        }
    },

}

这段程序出错,books 为什么没有成功赋值呢?
答案请看下面
1
1
1
1
1
1
1
1
1
1
1
1
1
1
1
1
1
1
1
1
1
1
1
1
1
1
1
1
1
1
1
1
1
1
1
1
1
1
1
1
1
1
1
1
1
1
1
1
1
1
1
1
1
1
1
是this指向问题,因为axios是异步执行,所以此时的this为undefined,才没有让books成功赋值,正确的应该是利用闭包来对主线程的this进行保存如下正确代码:

<script>
import axios from 'axios';
axios.defaults.baseURL='http://123.57.109.30:3006'
export default {
    methods:{
        getBook(){
            let that=this//用把this赋值给that
           axios({
               method:"GET",
               url:'/api/getbooks',
           }).then(function(e){
               that.books=[...e.data.data]
           }).catch(function(e){
               console.log(e);
           })
        },
    },
    data(){
        return{
            books:[],
        }
    },

}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值