微信小程序登陆个人信息授权 app 与 page 的执行顺序

初学微信小程序,总是搞不清app和page生命周期函数的执行先后顺序,尤其是在登陆授权个人信息这一板块,最近老是出现问题,所以本人仔细撸了一下代码,下面是自己的一些见解。因为刚接触小程序,见解不深,或者有错误的地方还请谅解,并帮忙指正。
建议在看我写的东西时,先看一下文章微信小程序不支持wx.getUserInfo授权的解决方法。我感觉他的文章还是写的比较完整的,对于新学者也是好理解的。好,废话不多说,大家还是喜欢用代码说话的。注意我打console的位置,还有文笔不好,见谅
app.js

  onLaunch: function (options) {
    console.log('刚进入onLaunch内部');
    // 展示本地存储能力
    var that = this;
    var logs = wx.getStorageSync('logs') || []
    logs.unshift(Date.now())
    wx.setStorageSync('logs', logs)
    // 获取用户信息
    wx.getSetting({
      success: res => {
        console.log('app.getSetting异步返回数据');
        var that = this;
        if (res.authSetting['scope.userInfo']) {
          // 已经授权,可以直接调用 getUserInfo 获取头像昵称,不会弹框
          wx.getUserInfo({
            success: res => {
              console.log('app.getUserInfo异步返回数据');
              // 可以将 res 发送给后台解码出 unionId
              that.globalData.userInfo = res.userInfo;
              that.globalData.iv = res.iv;
              that.globalData.encryptedData = res.encryptedData;
              // 由于 getUserInfo 是网络请求,可能会在 Page.onLoad 之后才返回
              // 所以此处加入 callback 以防止这种情况
              if (that.userInfoReadyCallback) {
                that.userInfoReadyCallback(res)
              }
            }
          })
        }
      }
    });
  },

index.js

  onLoad: function(options) {
    console.log('刚进入page.onLoad');
    console.log(this.data.canIUse);
    var that = this;
    wx.showShareMenu({
      withShareTicket: true
    });
    that.setData({
      sharedOptions: options
    })
    if (options.uid != undefined || options.uid != null) {
      that.setData({
        otherId: options.uid,
      });
    }
    if (app.globalData.userInfo) {
      console.log('page.onLoad 第一个条件');
      that.setData({
        userInfo: app.globalData.userInfo,
        hasUserInfo: true
      });
      if (that.data.uid == null) {
        that.setData({
          loadingShow: true
        })
        that.time(); //调用倒计时,5秒后请求数据
        that.code(); //登录接口
      }
    } else if (that.data.canIUse) {
      console.log('page.onLoad 第二个条件');
      // 由于 getUserInfo 是网络请求,可能会在 Page.onLoad 之后才返回
      // 所以此处加入 callback 以防止这种情况
      app.userInfoReadyCallback = res => {
        console.log('回调函数');
        that.setData({
          hasUserInfo: true
        });
        if (that.data.uid == null) {
          that.setData({
            loadingShow: true
          })
          that.time(); //调用倒计时,5秒后请求数据
          that.code(); //登录接口
        }
      }
    } else {
      console.log('page.onLoad 第三个条件');
      // 在没有 open-type=getUserInfo 版本的兼容处理
      wx.getUserInfo({
        success: res => {
          app.globalData.userInfo = res.userInfo
          that.setData({
            hasUserInfo: true
          });
          if (that.data.uid == null) {
            that.setData({
              loadingShow: true
            });
            that.time(); //调用倒计时,5秒后请求数据
            that.code(); //登录接口
          }
        }
      })
    };
  },
  //点击授权
  getUserInfo: function(e) {
    var that = this;
    if (e.detail.userInfo != undefined) {
      wx.getSetting({
        success: res => {
          var that = this;
          if (res.authSetting['scope.userInfo']) {
            console.log('index点击授权');
            console.log(that.data.canIUse);
            // 已经授权,可以直接调用 getUserInfo 获取头像昵称,不会弹框
            wx.getUserInfo({
              success: res => {
                // 可以将 res 发送给后台解码出 unionId
                app.globalData.userInfo = res.userInfo;
                app.globalData.iv = res.iv;
                app.globalData.encryptedData = res.encryptedData;
                if (that.data.uid == null) {
                  that.setData({
                    loadingShow: true
                  });
                  that.time(); //调用倒计时,5秒后请求数据
                  that.code(); //登录接口
                }
                // 由于 getUserInfo 是网络请求,可能会在 Page.onLoad 之后才返回
                // 所以此处加入 callback 以防止这种情况
                if (that.userInfoReadyCallback) {
                  that.userInfoReadyCallback(res)
                }
              }
            })
          }
        }
      })
      this.setData({
        hasUserInfo: true,
      })
    } else {
      wx.showModal({
        title: '警告',
        content: '您点击了拒绝授权,将无法正常使用7k7k的功能体验。',
        // success: function (res) {
        //   if (res.confirm) {
        //     wx.openSetting({
        //       success: function (res) {
        //         if (!res.authSetting["scope.userInfo"] || !res.authSetting["scope.userLocation"]) {
        //           //这里是授权成功之后 填写你重新获取数据的js
        //           //参考:
        //           that.getLogiCallback('', function () {
        //             callback('');
        //           })
        //         }
        //       }
        //     })
        //   }
        // }
      })
    }
  },
  onShow: function() {
    console.log('page.onShow');
    var that = this;
    if (app.globalData.uid != null) {
      that.setData({
        money: app.globalData.money,
        gameList: app.globalData.gameList
      })
      that.pageInitialization(); //获取栏目
      that.indexData(); //获取用户信息
      that.friendList(); //邀请成功列表
      that.shaerPage(); //分享页面跳转
    }

  },
  // 获取临时code
  code: function() {
    console.log('临时code');
    var that = this;
    wx.login({
      success: res => {
        // 发送 res.code 到后台换取 openId, sessionKey, unionId’
        app.globalData.code = res.code; //临时code
        wx.request({
          url: app.globalData.URL + '/api.php?c=system&do=getConfig&p=api',
          method: 'GET',
          success: function(res) {
            app.globalData.categoryId = res.data.data.id;
            that.login()
          }
        })
      }
    });
    // 获取用户信息
    wx.getSetting({
      success: res => {
        var that = this;
        if (res.authSetting['scope.userInfo']) {
          // 已经授权,可以直接调用 getUserInfo 获取头像昵称,不会弹框
          wx.getUserInfo({
            success: res => {
              // 可以将 res 发送给后台解码出 unionId
              app.globalData.userInfo = res.userInfo;
              app.globalData.iv = res.iv;
              app.globalData.encryptedData = res.encryptedData;
              // 由于 getUserInfo 是网络请求,可能会在 Page.onLoad 之后才返回
              // 所以此处加入 callback 以防止这种情况encryptedData)
              if (that.userInfoReadyCallback) {
                that.userInfoReadyCallback(res)
              }
            }
          })
        }
      }
    })
  },

授权情况下:
控制台输出结果


image.png

我自己画的流程图


image.png

流程图分析:
首先触发app.onLaunch函数,依次执行内部代码行,在运行到wx.getSetting函数时,由于是个异步,等待结果返回,但程序继续走,进行到index的onLoad函数,app.globalData.userInfo为null,所以进入第二个条件的代码块,并且定义了app.userInfoReadyCallback函数,然后进行到index.onShow,此时app.js中的getSetting数据返回,因为已经授权,继续wx.getUserInfo函数,userInfoReadyCallback为真,执行userInfoReadyCallback函数
未授权情况下:

控制台输出:


image.png

自己画的流程图
image.png

流程图分析:
首先触发app.onLaunch函数,依次执行内部代码行,在运行到wx.getSetting函数时,由于是个异步,等待结果返回,但程序继续走,进行到index的onLoad函数,app.globalData.userInfo为null,所以进入第二个条件的代码块,并且定义了app.userInfoReadyCallback函数,然后进行到index.onShow,此时app.js中的getSetting数据返回,因为未授权,wx.getUserInfo函数不执行,所以回调函数也不执行,只能人为点击授权,执行index页面的getUserInfo函数
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 158,560评论 4 361
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,104评论 1 291
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 108,297评论 0 243
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 43,869评论 0 204
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,275评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,563评论 1 216
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,833评论 2 312
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,543评论 0 197
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,245评论 1 241
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,512评论 2 244
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,011评论 1 258
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,359评论 2 253
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,006评论 3 235
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,062评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,825评论 0 194
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,590评论 2 273
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,501评论 2 268

推荐阅读更多精彩内容