小程序的坑—— setData不可以设置undefined

最近我们的小程序又出bug了,需求是很简单的查询,一个列表,每行有不同的单号,根据单号查询内容,bug表现为每次查询出来的内容都是一样的。

经测试发现,并不是每次查询出来的内容都是一样的,而是如果第一次查出来有内容,第二次查询失败没有内容,那么第二次会显示第一次的内容。

到这里我会想,是不是查询失败的情况下没有把之前的内容清空覆盖,然而我的代码是这样的,将查询内容expressInfo设置成了undefined:

  new Data().getExpressInfoInProduct(data).then(res => {
      this.setData({ expressInfo: { ...res }, loadingExpress: false });
    }).catch(res => {
      this.setData({ expressErr: res.message, 
                     expressInfo: undefined, 
                     loadingExpress: false 
                  });
    })

我发现AppData里数据已经没有了,只是页面没有渲染,这里百思不得其解。

后来在微信交流专区才知道将数据设置成undefined是不被允许的,不会在视图层中setData,只是在this.data中移除了而已。将undefined换成null,问题迎刃而解。

猜你喜欢

转载自blog.csdn.net/weixin_67585820/article/details/123641652
今日推荐