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

2023-10-27

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

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

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

  • 李宏毅2021年机器学习作业5(Seq2seq)实验记录

    李宏毅2021年机器学习作业5学习笔记 前言 一 问题描述 二 实验过程 2 1 基于RNN 2 2 基于Transformer 三 总结 前言 声明 本文参考了李宏毅机器学习2021年作业例程 开发平台是colab 一 问题描述 机器翻译
  • ClickHouse数据库与PHP的无缝集成

    ClickHouse数据库是一种基于列的数据库 支持高效数据的存储和查询 而PHP是一种流行的Web编程语言 被广泛应用于Web开发 在实际应用中 我们经常需要将PHP与ClickHouse进行集成 以实现高效的数据处理和查询 本文将探讨如
  • QT中事件及事件处理

    QT中事件及事件处理 什么是事件 事件与Qt中信号的区别 个人所见 事件是应用程序对内部或者外部的动作的统称 信号是事件的后续响应通知 例如你点击了一个按钮 物理上的鼠标点击动作就是事件 而程序收到事件时 就会发出按钮被按下的信号 通知按钮
  • mybatis+MySQL 新增数据返回主键id问题

    今天遇到个问题 怕自己又忘记 记录一下 有个需求 需要存入数据到MySQL后要返回主键id 我按照以前设置的方式得到的结果始终是1 就非常奇怪 找了原因 记录一下 int count userMapper insert user 拿到的是插
  • BigDecimal处理 四舍五入

    最近项目中遇到了关于BigDecimal取舍精度的问题 还遇到了一些坑 在此记录一下 public static void main String args BigDecimal bd new BigDecimal 10 5 int cou
  • python 微信授权 昵称乱码解决

    微信采用的是 ISO 8859 1 编码 所以只需要进行下面的转码 就可以了 先iso8859 1 解码 然后转换成 utf8 即可 print info nickname encode iso8859 1 decode utf8

随机推荐

  • oracle SGA

    三 实例内存结构和进程结构 由于内存结构和进程结构关系较紧密 进程会作用到对应的内存区域 比如数据库写入器作用到数据库缓冲区缓存中 日志写入器会作用到日志缓冲区 所以内存结构和进程结构会相互配合地进行描述 oracle实例内存结构由两部分组
  • Tensorboard打不开的解决方法

    最近在学习tensorflow 遇到了tensorboard打不开的现象 在网上在了一些方法 把他们全部总结在这里 1 如果在调用tensorboard之后 cmd中的链接打不开的话 可以试试127 0 0 1 6006或者localhos
  • 深度学习入门之SGD随机梯度下降法

    SGD SGD为随机梯度下降法 用数学式可以将 SGD 写成如下的式 6 1 这里把需要更新的权重参数记为W 把损失函数关于W的梯度记为 L W 表示学习率 实际上会取 0 01 或 0 001 这些事先决定好的值 式子中的 表示用右边的值
  • 群晖NAS的公网、NAT、DDNS、证书等配置一

    一 群辉NAS应用场景 你是否有过这样的需求 1 远程办公 日常的工作资料太多太杂乱 换个电脑根本没法工作 团队间资料共享太麻烦 Drive套件这个远程办公神器都能解决 我的文件相当于远程的 我的文档 团队文件 是可以与团队成员共享 在PC
  • 将ajax的值传给控制器,通过Ajax将三个下拉选择值作为参数传递给控制器

    您可以将变量searchRooms定义为全局 或其他一些合适的封闭范围 超出 change函数范围 并且在您进行AJAX调用时可以使用它 或者 您可以在执行AJAX调用时获取所需的值 与在 change函数中执行此操作的方式完全相同 事实上
  • powershell激活conda失败;无法加载文件 C:\Users\user\Documents\WindowsPowerShell\profile.ps1,因为在此系统上禁止运行脚本

    在执行vscode中 按F5调试python脚本时报以下错误 Exception has occurred ImportError DLL load failed 找不到指定的程序 File F Github ImageDiff Pytho
  • 获取宝塔Linux面板登陆地址账号和密码

    在ssh终端输入 etc init d bt
  • matlab rbf手写

    clc clear format long trainD 0 0 1 10 outD sin trainD trainD outD outD dnum length trainD 初始化参数学习率 lr w0 0 1 权值 lr c0 0
  • pip install mysqlclient报错

    安装mysqlclient时报错 先查看安装的python版本 python V 根据版本下载下载对应的 mysqlclient 文件 https www lfd uci edu gohlke pythonlibs mysqlclienth
  • 将本地项目上传到Github

    下次不要再忘了 虽然一直都在使用Github 但是经常不常用命令行都容易忘记掉 特意在此进行一次记录 1 在GitHub创建一个项目 2 在本地文件夹中 做一次Git初始化 Aliyun alioss 17 27 15 git init I
  • dw本地文件传不到远程服务器,用DW上传站点 怎么设置远程服务器

    用DW上传站点 怎么设置远程服务器 内容精选 换一换 本节操作介绍如何在Windows操作系统的本地主机上使用FTP上传文件到云服务器 已在待上传文件的云服务器中搭建 FTP 服务 如果您的云服务器为 Windows 操作系统 具体操作请参
  • PPPoE报文格式及交互详解

    简介 PPPoE报文的格式就是在以太网帧中携带PPP报文 如图所示 各个字段解释如下 Destination address 一个以太网单播目的地址或者以太网广播地址 0xffffffff 对于Discovery数据包来说 该域的值是单播或
  • 二叉搜索树 (BST) 的插入, 删除, 查找

    文章目录 二叉搜索树 BST 的定义 缺点 BST 的构建 BST 的插入 BST 的查询 BST 的删除 BST 的检验 二叉搜索树 BST 的定义 二叉搜索树 Binary Search Tree 的结点定义一般如下 typedef s
  • 数据仓库(3)数仓建模之星型模型与维度建模

    维度建模是一种将数据结构化的逻辑设计方法 也是一种广泛应用的数仓建模方式 它将客观世界划分为度量和上下文 度量是常常是以数值形式出现 事实周围有上下文包围着 这种上下文被直观地分成独立的逻辑块 称之为维度 它与实体 关系建模有很大的区别 实
  • Python人脸检测实战之疲劳检测

    本文主要介绍了实现疲劳检测 如果眼睛已经闭上了一段时间 我们会认为他们开始打瞌睡并发出警报来唤醒他们并引起他们的注意 感兴趣的朋友可以了解一下 今天我们实现疲劳检测 如果眼睛已经闭上了一段时间 我们会认为他们开始打瞌睡并发出警报来唤醒他们并
  • c语言编程函数名:b开头

    函数名 bar 功 能 画一个二维条形图 用 法 void far bar int left int top int right int bottom 程序例 include
  • LaTeX快速入门(超详细~)

    文章目录 LaTeX快速入门 前言 1 LaTeX源文件的基本结构 2 LaTeX中的中文处理方法 3 字体字号设置 3 1 字体族设置 3 2 字体系列设置 粗细 宽度 3 3 字体形状设置 3 4 中文字体设置 3 5 字体大小设置 4
  • vscode 添加全局宏定义

    问题 利用vscode编辑代码时 设置了禁用非活动区域着色后 在一些编译脚本中配置的宏又识别不了 遇到 ifdef包住的代码就会变暗色 想查看代码不是很方便 如下图 解决 在vscode中添加全局宏定义 步骤 1 ctrl shift p
  • 课时 6 自测题

    通过 Deployment 不能实现以下功能 单选题 A 应用扩缩容 B 应用发布回滚 C 应用重启 D 应用副本数量维持 一个 Deployment 中 哪些 labels selector 必须一致 单选题 A deployment L
  • 微信小程序首页数据初始化失败的解决方法

    一 问题描述 用户首次后再次进入小程序时 我们通常需要通过获取用户openid或unionid用作唯一标示与后台进行数据交流 初始化用户信息 当我们通过第三方服务器跟微信建立请求时 微信需要用户确认是否公开信息 如图1 从console可以