详解使用uni-app开发微信小程序之登录模块


Posted in Javascript onMay 09, 2019

从微信小程序官方发布的公告中我们可获知:小程序体验版、开发版调用 wx.getUserInfo 接口,将无法弹出授权询问框,默认调用失败,需使用 <button open-type="getUserInfo"></button> 引导用户主动进行授权操作:

1.当用户未授权过,调用该接口将直接报错

2.当用户授权过,可以使用该接口获取用户信息

但在实际开发中我们可能需要弹出授权询问框,因此需要我们自己来写模拟授权弹框(主要是对<buttonopen-type="getUserInfo"></button>的包裹+用户是否是第一次授权判断来显示该页面),代码如下:

1.页面结构

<template>
  <view>
    <!-- #ifdef MP-WEIXIN -->
    <view v-if="isCanUse">
      <view>
        <view class='header'>
          <image src='../../static/img/wx_login.png'></image>
        </view>
        <view class='content'>
          <view>申请获取以下权限</view>
          <text>获得你的公开信息(昵称,头像、地区等)</text>
        </view>

        <button class='bottom' type='primary' open-type="getUserInfo" withCredentials="true" lang="zh_CN" @getuserinfo="wxGetUserInfo">
          授权登录
        </button>
      </view>
    </view>
    <!-- #endif -->
  </view>
</template>

这里的isCanUse是用来记录当前用户是否是第一次授权使用的,wx_login.png图在底部下载获取即可。

2.样式

<style>
  .header {
    margin: 90rpx 0 90rpx 50rpx;
    border-bottom: 1px solid #ccc;
    text-align: center;
    width: 650rpx;
    height: 300rpx;
    line-height: 450rpx;
  }

  .header image {
    width: 200rpx;
    height: 200rpx;
  }

  .content {
    margin-left: 50rpx;
    margin-bottom: 90rpx;
  }

  .content text {
    display: block;
    color: #9d9d9d;
    margin-top: 40rpx;
  }

  .bottom {
    border-radius: 80rpx;
    margin: 70rpx 50rpx;
    font-size: 35rpx;
  }
</style>

3.脚本部分

<script>
  export default {
    data() {
      return {
        SessionKey: '',
        OpenId: '',
        nickName: null,
        avatarUrl: null,
        isCanUse: uni.getStorageSync('isCanUse')||true//默认为true
      };
    },
    methods: {
      //第一授权获取用户信息===》按钮触发
      wxGetUserInfo() {
        let _this = this;
        uni.getUserInfo({
          provider: 'weixin',
          success: function(infoRes) {
            let nickName = infoRes.userInfo.nickName; //昵称
            let avatarUrl = infoRes.userInfo.avatarUrl; //头像
            try {
              uni.setStorageSync('isCanUse', false);//记录是否第一次授权 false:表示不是第一次授权
              _this.updateUserInfo();
            } catch (e) {}
          },
          fail(res) {}
        });
      },



//登录
        login() {
        let _this = this;
        uni.showLoading({
          title: '登录中...'
        });
       
        // 1.wx获取登录用户code
        uni.login({
          provider: 'weixin',
          success: function(loginRes) {
            let code = loginRes.code;
            if (!_this.isCanUse) {
              //非第一次授权获取用户信息
              uni.getUserInfo({
                provider: 'weixin',
                success: function(infoRes) {
 










//获取用户信息后向调用信息更新方法
                  let nickName = infoRes.userInfo.nickName; //昵称
                  let avatarUrl = infoRes.userInfo.avatarUrl; //头像
                    _this.updateUserInfo();//调用更新信息方法
                }
              });
            }
      
            //2.将用户登录code传递到后台置换用户SessionKey、OpenId等信息
            uni.request({
              url: '服务器地址',
              data: {
                code: code,
              },
              method: 'GET',
              header: {
                'content-type': 'application/json'
              },
              success: (res) => {
                //openId、或SessionKdy存储//隐藏loading
                uni.hideLoading();
              }
            });
          },
        });
      },
     //向后台更新信息
      updateUserInfo() {
        let _this = this;
        uni.request({
          url:'url' ,//服务器端地址
          data: {
            appKey: this.$store.state.appKey,
            customerId: _this.customerId,
            nickName: _this.nickName,
            headUrl: _this.avatarUrl
          },
          method: 'POST',
          header: {
            'content-type': 'application/json'
          },
          success: (res) => {
            if (res.data.state == "success") {
              uni.reLaunch({//信息更新成功后跳转到小程序首页
                url: '/pages/index/index'
              });
            }
          }
          
        });
      }
    },
    onLoad() {//默认加载
      this.login();
    }
  }
</script>

4.最终效果如下:

详解使用uni-app开发微信小程序之登录模块 

详解使用uni-app开发微信小程序之登录模块

wx_login.png图:

详解使用uni-app开发微信小程序之登录模块

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
jQuery UI Dialog控件中的表单无法正常提交的解决方法
Dec 19 Javascript
js取整数、取余数的方法
May 11 Javascript
jQuery选择id属性带有点符号元素的方法
Mar 17 Javascript
JS弹出层遮罩,隐藏背景页面滚动条细节优化分析
Apr 29 Javascript
JS简单实现仿百度控制台输出信息效果
Sep 04 Javascript
微信公众号-获取用户信息(网页授权获取)实现步骤
Oct 21 Javascript
Angular2整合其他插件的方法
Jan 20 Javascript
Vue精简版风格指南(推荐)
Jan 30 Javascript
vue 表单之通过v-model绑定单选按钮radio
May 13 Javascript
es6中reduce的基本使用方法
Sep 10 Javascript
JavaScript实现单图片上传并预览功能
Sep 30 Javascript
如何配置vue.config.js 处理static文件夹下的静态文件
Jun 19 Javascript
D3.js的基础部分之数组的处理数组的排序和求值(v3版本)
May 09 #Javascript
JS原型与继承操作示例
May 09 #Javascript
详解微信小程序回到顶部的两种方式
May 09 #Javascript
jquery登录的异步验证操作示例
May 09 #jQuery
D3.js(v3)+react 实现带坐标与比例尺的散点图 (V3版本)
May 09 #Javascript
D3.js(v3)+react 实现带坐标与比例尺的柱形图 (V3版本)
May 09 #Javascript
vue 引用自定义ttf、otf、在线字体的方法
May 09 #Javascript
You might like
索尼ICF-SW100收音机评测
2021/03/02 无线电
PHP+SQL 注入攻击的技术实现以及预防办法
2010/12/29 PHP
PHP PDOStatement::bindValue讲解
2019/01/30 PHP
php转换上传word文件为PDF的方法【基于COM组件】
2019/06/10 PHP
使用js操作cookie的一点小收获分享
2013/09/03 Javascript
JS判断客服QQ号在线还是离线状态的方法
2015/01/13 Javascript
JavaScript中判断函数、变量是否存在
2015/06/10 Javascript
javascript实现继承的简单实例
2015/07/26 Javascript
jQuery+css3实现文字跟随鼠标的上下抖动
2015/07/31 Javascript
jQuery 1.9.1源码分析系列(十五)之动画处理
2015/12/03 Javascript
js实现div模拟模态对话框展现URL内容
2016/05/27 Javascript
总结JavaScript的正则与其他语言的不同之处
2016/08/25 Javascript
jQuery 获取select选中值及清除选中状态
2016/12/13 Javascript
javascript 动态生成css代码的两种方法
2017/03/17 Javascript
vue2.0 自定义日期时间过滤器
2017/06/07 Javascript
vue中el-input绑定键盘按键(按键修饰符)
2020/07/22 Javascript
javascript前端和后台进行数据交互方法示例
2020/08/07 Javascript
Element-ui upload上传文件限制的解决方法
2021/01/22 Javascript
Python time模块详解(常用函数实例讲解,非常好)
2014/04/24 Python
python获取当前用户的主目录路径方法(推荐)
2017/01/12 Python
Python简单计算数组元素平均值的方法示例
2017/12/26 Python
Python matplotlib画图实例之绘制拥有彩条的图表
2017/12/28 Python
Python系统监控模块psutil功能与经典用法分析
2018/05/24 Python
python单例模式获取IP代理的方法详解
2018/09/13 Python
python学生信息管理系统(完整版)
2020/04/05 Python
Python一个简单的通信程序(客户端 服务器)
2019/03/06 Python
Python实现报警信息实时发送至邮箱功能(实例代码)
2019/11/11 Python
python3中的logging记录日志实现过程及封装成类的操作
2020/05/12 Python
pandas 按日期范围筛选数据的实现
2021/02/20 Python
日本最大的药妆连锁店:Matsukiyo松本清药妆店
2017/11/23 全球购物
家长会学生家长演讲稿
2013/12/29 职场文书
秋季运动会广播稿
2014/02/22 职场文书
商业企业管理专业求职信
2014/07/10 职场文书
2015年父亲节活动总结
2015/02/12 职场文书
2015年幼儿教师个人工作总结
2015/05/20 职场文书
2016新教师培训心得体会范文
2016/01/08 职场文书