一、 问题描述

用户首次后再次进入小程序时,我们通常需要通过获取用户openid或unionid用作唯一标示与后台进行数据交流,初始化用户信息。当我们通过第三方服务器跟微信建立请求时,微信需要用户确认是否公开信息。如图1,从console可以看到,在请求的同时,我们的首页index已经加载完成,图中初始化数据显示为空。无论我们将请求信息写在app.js的onload中或者index.js中,当我们点击确认后,请求信息才执行success方法,将第三方服务器返回的数据处理,这样的因需要用户点击而产生的滞后性,我们很难要求程序停下来等我们。那么,我们可以通过其他途径,来达到让程序“停下来”的错觉,下面容我来介绍一下我的解决方法。

图1

二、 解决方法的最基本要求

我们想要的解决方法的最基本要求有如下两点:

1) 当我们进入主页,数据完成了初始化,并正常显示

2) 当用户首次进入程序,只需确认确认公开信息,即可正常进入主页

三、 解决方法

我的解决方法是:通过设计一个“临时加载页”来达到我们想要的效果,这个临时加载页类似于Android的欢迎界面,但当数据加载完成,或者我在第二次进入时,将自动跳转到我们的主页。下面是设计代码部分。

步骤一:首先我们在app.json中,创建一个新的page,命名为welcome

"pages/welcome/welcome"

注意该page要放置在首页,也就是程序进来第一个页面

步骤二:我们在welcome.js中,将具体请求操作写入到onload中

// pages/welcome/welcome.js

Page({

data:{},

onLoad:function(options){

// 页面初始化 options为页面跳转所带来的参数

var that = getApp()

try {

//首先检查缓存中是否有我们需要请求的数据,如果没有,我们再跟服务器连接,获取数据

//首次登陆肯定是没有的

that.globalData.userInfo = wx.getStorageSync('userInfo')

if(wx.getStorageSync('userInfo')!=''){

//如果缓存不为空,即已经存在数据,我们不用再跟服务器交互了,那么直接跳转到首页

wx.switchTab({

url: '../index/index',

})

}

if (value) {

// Do something with return value

console.log(that.globalData.userInfo)

}

} catch(e){

// Do something when catch error

//当try中的缓存数据不存在时,将跳到这步,这步中,我们将与服务器进行连接,并获取数据

if(that.globalData.userInfo == ''){

wx.login({

success: function(res) {

//获取用户code,转发到我们的服务器,再在我们服务器与微信交互,获取openid

var code = res.code

wx.getUserInfo({

success: function(userInfo) {

var encryptedData = userInfo.encryptedData

var iv = userInfo.iv

//我们服务器请求地址

var url = that.apiHost + 'index/login'

var userinfo = userInfo.userInfo

var username = userinfo.nickName

var useravatar =userinfo.avatarUrl

var usersex=userinfo.gender

wx.request({

url: url,

method: 'POST',

data: {

'code': code,

'username':username,

'useravatar':useravatar,

'usersex':usersex

},

header: {

"Content-Type": "application/x-www-form-urlencoded"

},

success:function(response) {

//数据交互成功后,我们将服务器返回的数据写入全局变量与缓存中

console.log(response.data)

//写入全局变量

that.globalData.userInfo = response.data

wx.hideToast()

//写入缓存

wx.setStorage({

key: 'userInfo',

data: that.globalData.userInfo,

success: function(res){

console.log("insert success")

},

fail: function() {

// fail

},

complete: function() {

// complete

}

})

//写入后,我们将跳转到主页

wx.switchTab({

url: '../index/index',

})

},

failure: function(error) {

console.log(error)

},

})

}

})

}

})}

}

},

onReady:function(){

// 页面渲染完成

},

onShow:function(){

// 页面显示

},

onHide:function(){

// 页面隐藏

},

onUnload:function(){

// 页面关闭

},

redirect:function(){

wx.switchTab({

url: '../index/index',

})

}

})

可看到,我们在首次登陆时,将进入我们的欢迎界面,当用户确认公开信息后,页面将自动跳转到首页,首页数据正常显示

在第二次进入时,跳转在onload中就进行了,界面还没渲染就跳转了,所以速度很快,亲测跳转还算满意,但终究还是绕个弯来做一件事,大家若有更好的方法,也请分享分享,谢谢!

以上所述是小编给大家介绍的微信小程序首页数据初始化失败的解决方法,希望对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会及时回复大家的!

微信小程序android错误,微信小程序首页数据初始化失败的解决方法相关推荐

  1. 头脑王者服务器维护,微信头脑王者请求超时及查询服务器失败的解决方法

    微信头脑王者你们知道吗?不知道也没有关系哦,以下内容是微信头脑王者请求超时及查询服务器失败的解决方法,一起来学习吧! 头脑王者请求超时怎么解决? 1.最常见的就是wifi网络环境下出现这种情况,这是因 ...

  2. java连接数据库12514_ORA-12514 TNS 监听程序当前无法识别连接描述符中请求服务 的解决方法...

    早上同事用PL/SQL连接虚拟机中的Oracle数据库,发现又报了"ORA-12514 TNS 监听程序当前无法识别连接描述符中请求服务"错误,帮其解决后,发现很多人遇到过这样的问 ...

  3. 微信token验证失败的解决方法

    微信token验证失败的解决方法 参考文章: (1)微信token验证失败的解决方法 (2)https://www.cnblogs.com/kenshinobiy/p/5433705.html 备忘一 ...

  4. windows7 ORA-12514 TNS 监听程序当前无法识别连接描述符中请求服务 的解决方法

    windows7 ORA-12514 TNS 监听程序当前无法识别连接描述符中请求服务 的解决方法 参考文章: (1)windows7 ORA-12514 TNS 监听程序当前无法识别连接描述符中请求 ...

  5. python程序在命令行执行提示ModuleNotFoundError: No module named ‘XXX‘ 解决方法

    python程序在命令行执行提示ModuleNotFoundError: No module named 'XXX' 解决方法 参考文章: (1)python程序在命令行执行提示ModuleNotFo ...

  6. windows查看端口占用 windows端口占用 查找端口占用程序 强制结束端口占用 查看某个端口被占用的解决方法 如何查看Windows下端口占用情况

    windows查看端口占用 windows端口占用 查找端口占用程序 强制结束端口占用 查看某个端口被占用的解决方法 如何查看Windows下端口占用情况 参考文章: (1)windows查看端口占用 ...

  7. 微信开发学习 问题1: 网页授权问题 “该连接无法访问” 解决方法

    微信开发学习 问题1: 网页授权问题 "该连接无法访问" 解决方法 参考文章: (1)微信开发学习 问题1: 网页授权问题 "该连接无法访问" 解决方法 (2) ...

  8. 微信支付curl: (60) SSL certificate problem: unable to get local issuer certificate 解决方法

    微信支付curl: (60) SSL certificate problem: unable to get local issuer certificate 解决方法 参考文章: (1)微信支付cur ...

  9. 按“Win+E”键出现【找不到应用程序】或【explore.exe找不到】的解决方法

    Win+R一波三折 重装系统后Win+E(打开资源管理器的快捷键)就打不开了,感觉是这系统不纯净导致的-- 找了很多方法都不管用(重新下载explore,运行啥命令什么的--),一波三折,昨天好不容易 ...

最新文章

  1. ADPRL - 近似动态规划和强化学习 - Note 10 - 蒙特卡洛法和时序差分学习及其实例 (Monte Carlo and Temporal Difference)
  2. shell中复制粘贴随笔
  3. FreeRTOS的中断优先级配置小结
  4. shell模拟php多进程从redis获取数据(多个库)
  5. 架构分享--微博架构
  6. Java的正则表达式
  7. 坦克世界 与服务器连接中断,坦克世界怎么老是显示与服务器连接已中断
  8. Struts2 Servelet重构
  9. jboss7.1.0配置数据库(mysql)
  10. 使用Box2D制作AS3游戏——2.1a版本——Hello World Box2D .
  11. java启动mysq服务_启动和关闭MySQL服务
  12. 计算机人力资源试题及答案,计算机二级word练习题一题目及答案.
  13. Eclipse SVN图标等设置
  14. 整理电力系统GPS时间同步装置(GPS对时系统)孤岛方案
  15. React 脚手架使用
  16. 2010年10月14日糗事TOP10
  17. 基于java植物大全智能识别系统设计与实现
  18. 第八届“图灵杯”NEUQ-ACM程序设计竞赛个人赛非官方题解
  19. 教务管理系统(免费源码获取)
  20. Dockerfile 中 CMD 写法的区别

热门文章

  1. 学魅族手滑,中兴红牛V5抢购标错价
  2. 配置Apache实现url转发
  3. 视频画质不清晰的解决方法
  4. 目标检测yolov3+文字识别CRNN 实现文本检测和识别
  5. 最小二乘法抛物线 c语言,C语言实现最小二乘法抛物线拟合
  6. 金融数据分析 实验三 金融时间序列分析
  7. Activiti介绍及视频教程
  8. 【第49题】常用的数学工具类6-高精度整数运算
  9. KafkaController创建topic流程解析
  10. RocketMQ 常用命令实战