• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    迪恩网络公众号

小程序登录/授权/个人信息/敏感信息/缓存/音效

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

1.登录授权

在需要查询是否登录的地方,我这里是在首页的onready中

  onReady: function () {
    //是否授权
    wx.getSetting({
      success: res => {
        if (res.authSetting[\'scope.userInfo\']) {
          //已经授权,可以直接调用 getUserInfo 获取头像昵称,不会弹框
          console.log("已经授权");
          wx.getUserInfo({
            success: function (res){
              app.globalData.userInfo = res.userInfo
            }
          })
        } else {
          console.log("未授权跳转login");
          wx.navigateTo({
            url: \'/pages/login/login\',
          })
        }
      }
    })
  },

 //我这里没有将个人信息存入缓存中,也可以存入缓存然后通过缓存中是否有用户信息来判断是否授权

Login界面中有一个登录按钮

<button  class=\'login-btn\' open-type=\'getUserInfo\' lang=\'zh_CN\' bindgetuserinfo=\'onGotUserInfo\' hover-class=\'btn-hover\' >微信登录</button>

点击方法:

  onGotUserInfo: function (e) {
    console.log(\'errMsg:\'+e.detail.errMsg)
    console.log(+e.detail.userInfo)
    console.log(\'rawData:\'+e.detail.rawData)
    if(e.detail.userInfo){
      console.log(\'点击了授权\')
      app.globalData.userInfo = e.detail.userInfo
      wx.login({
        success: function(res){
          console.log(res)
          //返回临时凭证code 传入后台获取openid和session_key
          wx.request({
            url: \'testurl\',
            data:{
              code:res.code
            },
            method:\'POST\',
            header:{
              \'content-type\': \'application/json\' // 默认值
            },
            success: function(res){
              console.log(res)
            }

          })
        }
      })
    }else{
      console.log(\'拒绝了授权\')
    }
    wx.navigateBack({
      
    })
  },

 2.音效的使用

直接用innerAudioContext播放URL会有延迟,体验很差,可以将资源存入缓存中,通过PATH来播放

globaldata中:

    home_btn:\'\',
    next_question:\'\',
    wrong_1:\'\',
    wrong_2: \'\',
    right_1:\'\',
    right_2:\'\',
    unit_pass_1:\'\',
    unit_pass_2:\'\',
    unit_pass_3:\'\',
    unit_fail:\'\',
    game_pass_1:\'\',
    game_pass_2:\'\',
    game_pass_3:\'\',
    game_fail:\'\',

 

onLaunch中:
    self.saveAudioFile(\'home_btn\')
    self.saveAudioFile(\'next_question\')

saveAuidoFile方法:

saveAudioFile:function(fileName){
    var self = this;
    //先判断缓存中是否存在
    wx.getStorage({
      key: fileName,
      success: function(res) {
        //存在的话直接赋值给globaldata
        self.globalData[fileName] = res.data
      },
      fail: function(res){
        //不存在,将提示音存入本地缓存
        wx.downloadFile({
          url: self.globalData.audioHeader + fileName + \'.mp3\',
          success(res) {
            wx.saveFile({
              tempFilePath: res.tempFilePath,
              success(res) {
                wx.setStorage({
                  key: fileName,
                  data: res.savedFilePath,
                })
                //赋值给globaldata
                self.globalData[fileName] = res.savedFilePath
              },
              fail(res) {
                console.log(res)
              }
            })
          }
        })
      }
    })
  },

 播放:

  pointAudioPlay: function (name){
    innerAudioContext.src = app.globalData.home_btn
    innerAudioContext.play()
  },

 很方便效果也很好!

 

 


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
微信小程序文档里看不到的小Tips发布时间:2022-07-18
下一篇:
小程序排错(redis导致)发布时间:2022-07-18
热门推荐
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap