全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

微信小程序首页数据初始化失败的解决方法

一、 问题描述

用户首次后再次进入小程序时,我们通常需要通过获取用户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中就进行了,界面还没渲染就跳转了,所以速度很快,亲测跳转还算满意,但终究还是绕个弯来做一件事,大家若有更好的方法,也请分享分享,谢谢!

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


# 微信小程序  # 数据初始化失败  # 微信小程序开发之点击按钮退出小程序的实现方法  # 微信小程序 setData使用方法及常用错误解决办法  # 微信小程序中显示html格式内容的方法  # 微信小程序 setData的使用方法详解  # 微信小程序动态的显示或隐藏控件的方法(两种方法)  # 微信小程序 传值取值的几种方法总结  # 微信小程序 详解下拉加载与上拉刷新实现方法  # 微信小程序 页面跳转传递值几种方法详解  # 如何在微信小程序里面退出小程序的方法  # 首页  # 解决方法  # 首次  # 跳转  # 跳转到  # 当我们  # 加载  # 公开信息  # 停下来  # 第三方  # 基本要求  # 小编  # 为空  # 正常显示  # 再跟  # 这步  # 全局变量  # 我在  # 还没  # 第一个 


相关文章: 如何快速生成可下载的建站源码工具?  无锡营销型网站制作公司,无锡网选车牌流程?  香港服务器如何优化才能显著提升网站加载速度?  公司网站建设制作费用,想建设一个属于自己的企业网站,该如何去做?  建站之星如何保障用户数据免受黑客入侵?  如何访问已购建站主机并解决登录问题?  专业网站制作服务公司,有哪些网站可以免费发布招聘信息?  阿里云网站制作公司,阿里云快速搭建网站好用吗?  购物网站制作费用多少,开办网上购物网站,需要办理哪些手续?  建站主机功能解析:服务器选择与快速搭建指南  如何用免费手机建站系统零基础打造专业网站?  如何在宝塔面板中创建新站点?  制作网站的软件下载免费,今日头条开宝箱老是需要下载怎么回事?  如何快速登录WAP自助建站平台?  小程序网站制作需要准备什么资料,如何制作小程序?  如何在Golang中实现微服务服务拆分_Golang微服务拆分与接口管理方法  装修招标网站设计制作流程,装修招标流程?  如何自定义建站之星网站的导航菜单样式?  如何在Ubuntu系统下快速搭建WordPress个人网站?  整人网站在线制作软件,整蛊网站退不出去必须要打我是白痴才能出去?  如何快速搭建安全的FTP站点?  Android自定义listview布局实现上拉加载下拉刷新功能  企业网站制作费用多少,企业网站空间一般需要多大,费用是多少?  制作网站的网址是什么,请问后缀为.com和.com.cn还有.cn的这三种网站是分别是什么类型的网站?  ,在苏州找工作,上哪个网站比较好?  宝塔新建站点为何无法访问?如何排查?  网站企业制作流程,用什么语言做企业网站比较好?  定制建站平台哪家好?企业官网搭建与快速建站方案推荐  建站之星下载版如何获取与安装?  北京网站制作公司哪家好一点,北京租房网站有哪些?  家族网站制作贴纸教程视频,用豆子做粘帖画怎么制作?  制作无缝贴图网站有哪些,3dmax无缝贴图怎么调?  Swift中switch语句区间和元组模式匹配  制作电商网页,电商供应链怎么做?  高端企业智能建站程序:SEO优化与响应式模板定制开发  如何在香港服务器上快速搭建免备案网站?  如何在万网ECS上快速搭建专属网站?  官网自助建站系统:SEO优化+多语言支持,快速搭建专业网站  如何打造高效商业网站?建站目的决定转化率  如何通过云梦建站系统实现SEO快速优化?  在线教育网站制作平台,山西立德教育官网?  网站建设制作、微信公众号,公明人民医院怎么在网上预约?  详解一款开源免费的.NET文档操作组件DocX(.NET组件介绍之一)  湖州网站制作公司有哪些,浙江中蓝新能源公司官网?  广德云建站网站建设方案与建站流程优化指南  如何设置并定期更换建站之星安全管理员密码?  网站制作多少钱一个,建一个论坛网站大约需要多少钱?  建站之星代理平台如何选择最佳方案?  制作网页的网站有哪些,电脑上怎么做网页?  建站主机服务器选购指南:轻量应用与VPS配置解析 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。