详解使用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插件简单实现代码
Apr 19 Javascript
JavaScript中setAttribute用法介绍
Jul 20 Javascript
利用js(jquery)操作Cookie的方法说明
Dec 19 Javascript
JS实现仿QQ聊天窗口抖动特效
May 10 Javascript
JQuery实现Ajax加载图片的方法
Dec 24 Javascript
详解jQuery Mobile自定义标签
Jan 06 Javascript
vue+mockjs模拟数据实现前后端分离开发的实例代码
Aug 08 Javascript
webpack+vue中使用别名路径引用静态图片地址
Nov 20 Javascript
CSS3结合jQuery实现动画效果及回调函数的实例
Dec 27 jQuery
layui select动态添加option的实例
Mar 07 Javascript
小程序测试后台服务的方法(ngrok)
Mar 08 Javascript
vue设置动态请求地址的例子
Nov 01 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
ADODB类使用
2006/11/25 PHP
简单的PHP留言本实例代码
2010/05/09 PHP
PhpMyAdmin出现export.php Missing parameter: what /export_type错误解决方法
2012/08/09 PHP
destoon实现商铺管理主页设置增加新菜单的方法
2014/06/26 PHP
使用PHP生成二维码的方法汇总
2015/07/22 PHP
Thinkphp结合ajaxFileUpload实现异步图片传输示例
2017/03/13 PHP
Yii2语言国际化的配置教程
2018/08/19 PHP
新增加的内容是如何将div的scrollbar自动移动最下面
2014/01/02 Javascript
Jquery ajax请求导出Excel表格的实现代码
2016/06/08 Javascript
AngularJS实现按钮提示与点击变色效果
2016/09/07 Javascript
最全面的JS倒计时代码
2016/09/17 Javascript
自学实现angularjs依赖注入
2016/12/20 Javascript
nodejs使用express创建一个简单web应用
2017/03/31 NodeJs
Angular.js自动化测试之protractor详解
2017/07/07 Javascript
VsCode新建VueJs项目的详细步骤
2017/09/23 Javascript
原生JS封装_new函数实现new关键字的功能
2018/08/12 Javascript
微信小程序保存多张图片的实现方法
2019/03/05 Javascript
vue v-for 点击当前行,获取当前行数据及event当前事件对象的操作
2020/09/10 Javascript
Vue如何实现变量表达式选择器
2021/02/18 Vue.js
Python实现八大排序算法
2016/08/13 Python
详解python3百度指数抓取实例
2016/12/12 Python
Python中的探索性数据分析(功能式)
2017/12/22 Python
Python BS4库的安装与使用详解
2018/08/08 Python
Python对CSV、Excel、txt、dat文件的处理
2018/09/18 Python
python 递归深度优先搜索与广度优先搜索算法模拟实现
2018/10/22 Python
详解python中的数据类型和控制流
2019/08/08 Python
pd.DataFrame统计各列数值多少的实例
2019/12/05 Python
Python tkinter实现图片标注功能(完整代码)
2019/12/08 Python
Numpy与Pytorch 矩阵操作方式
2019/12/27 Python
在pycharm中使用pipenv创建虚拟环境和安装django的详细教程
2020/11/30 Python
Nike台湾官方商店:Nike.com (TW)
2017/08/16 全球购物
台湾良兴购物网:EcLife
2019/12/01 全球购物
一些Unix笔试题和面试题
2012/09/25 面试题
人力资源部培训专员岗位职责
2014/01/02 职场文书
浅谈Node的内存泄露问题
2022/05/06 NodeJs
HTML5页面打开微信小程序功能实现
2022/09/23 HTML / CSS