微信小程序变量赋值失败 - 新闻资讯 - 云南小程序开发|云南软件开发|云南网站建设-昆明葵宇信息科技有限公司

159-8711-8523

云南网建设/小程序开发/软件开发

知识

不管是网站,软件还是小程序,都要直接或间接能为您产生价值,我们在追求其视觉表现的同时,更侧重于功能的便捷,营销的便利,运营的高效,让网站成为营销工具,让软件能切实提升企业内部管理水平和效率。优秀的程序为后期升级提供便捷的支持!

您当前位置>首页 » 新闻资讯 » 小程序相关 >

微信小程序变量赋值失败

发表时间:2020-10-20

发布人:葵宇科技

浏览次数:74

本人一直以来都是C程序员,最近有需求,需要做个微信小程序,其中有不少坎坷。C语言编程和高级语言相比,思维逻辑还是有些不一样的。例如今天遇到的问题,我在onload函数中给一个变量赋值,紧接着要使用,但发现变量依旧是空的,代码如下:

  
onLoad: function (options) {
    news.limit(5).get({
      success:res=>{
        this.setData({newsList:res.data})
      }
    })

    console.log(this.data.newsList);
    this.setSwiperImg();//这个函数中用到了newsList变量
    
  }

实际发现后面日志和setSwiperImg()函数中用到的newsList都是空的。但是在调试窗口查看变量是有值的。

其实老鸟可能一眼就看出了上面代码的问题,我的思维一直固化在C的顺序执行里面(虽然C也可以做到异步执行,但是大多数时候都是顺序执行的)。最后想了半天,终于顿悟了:

      success:res=>{
        this.setData({newsList:res.data})
      }

这个应该是个回调函数,在news.limit(5).get执行成功后,异步回调执行。所以在时间上是滞后的。在我后面语句使用到newsList变量的时候,回调还没执行呢。既然想通了,那么立即修改为:

  onLoad: function (options) {
    news.limit(5).get({
      success:res=>{
        this.setData({newsList:res.data})
        console.log(this.data.newsList);
        this.setSwiperImg();
      }
    })
  },

保存,运行,OK!

相关案例查看更多