html + vue + axios能获取数据但是页面标签中无法渲染

html + vue + axios能获取数据但是无法渲染

 axios
          .get("/baseData")
          .then(function (data) {
            // 
            this.reelSizeMap= data.data.reelSizeMap
          })

此时页面是无法渲染的,原因是then里面不能使用vue实例化的this,因为内部this没有被绑定,解决方法
1.用ES6箭头函数,箭头方法没有this,可以和父方法共享变量
2.在请求axios外面定义一下 var that=this

使用方法一 修改:
箭头函数

    axios
          .get("/baseData")
          .then( data => {
            // 类型数据
            this.reelSizeMap= data.data.reelSizeMap
          })

方法二修改:

    var that=this
    axios
          .get("/baseData")
          .then(function (data ) {
            // 类型数据
            that.reelSizeMap= data.data.reelSizeMap
          })

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值