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

微信小程序登录组件封装 —— 完成已登录状态才能继续的操作 ...

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

小编推荐:Fundebug专注于JavaScript、微信小程序、微信小游戏,Node.js和Java实时BUG监控。真的是一个很好用的bug监控费服务,众多大佬公司都在使用。

  • 此组件是项目中用到的,项目结束了,分享给大家,希望能对大家有所帮助
  • 这里只讨论怎样解决需要已登录状态才能继续操作,具体登录逻辑不做讨论
  • 源码已经上传GitHub --> zy-login-view 求Star

需要已登录状态才能继续操作这个具体应用场景我相信产品经理们能够给你一个详情解答

这里我们具体分析一下:

  • 我们点击一个视图View(其实很少是Button,而登录却需要Button)进行某项操作
  • --> 已登录 --> 执行该操作
  • --> 未登录 --> 登录 --> 自动继续该操作

当然其中登录还有以下情况:

  • 登录时 --> 发现没有注册(很多项目是以绑定手机号与否认定是否注册,虽然有违微信小程序的快捷与方便的初衷,但是确实存在)--> 跳转注册页面 --> 注册成功 --> 返回此页面(一般走了注册流程的返回源页面就行了)

本组件实现方式是:

  • 判断是否登录
  • 已登录 --> 将原来的视图插入本组件的<slot></slot>中 --> triggerEvent
  • 未登录 --> 写一个透明button覆盖原来视图 --> login(判断权限,登录,注册,处理数据等等。。。可以封装一个login.js文件专门处理这些东西) --> 登录成功 --> triggerEvent

js主要代码

    // 未登录状态
    //获取用户信息
    handleUserInfo: function (e) {
      if (e.detail.errMsg ===
        "getUserInfo:ok") {
        wx.showLoading({
          title: '登录中...',
          mask: true,
        });

        // 这里是一个登录的相关操作的封装,引入的外部js文件
        // login().then(() => {
        //   this.triggerEvent('onLoginSuccess', {
        //     payload: this.data.payload
        //   })
        // })

        //模拟登录
        setTimeout(() => {
          wx.setStorageSync('isLogin', true);
          wx.hideLoading();
          this.triggerEvent('onLoginSuccess', {
            payload: this.data.payload
          })
        }, 2000) 

      } else {
        wx.showToast({
          title: "登录失败,请稍后重试",
          icon: 'none'
        });
      }
    },

    //已登录状态
    handleTap: function () {
      this.triggerEvent('onLoginSuccess', {
        payload: this.data.payload
      })
    }

wml主要代码

<view class='container' bindtap="handleTap" wx:if="{{isLogin}}">
    <slot></slot>
</view>
<view class='container' wx:else>
    <button
            class='auth'
            open-type="getUserInfo"
            bindgetuserinfo="handleUserInfo"
    >
        授权登录
    </button>
    <slot></slot>
</view>
  

使用方法:

  • .json文件引入
{
  "usingComponents": {
    "login-view": "../../component/login-view/login-view"
  }
}
  • .wxml使用
<login-view hasLogin='{{hasLogin}}' payload='sendInData<AnyType>' bind:onLoginSuccess="jumpToLogsPage">
   <view class='login'>已登录状态才能跳转</view>
</login-view>
  • .js文件中,就当此判断不存在,比如此例中正常使用,data就是传入登录组件的参数,可以穿任意类型,原样返回。需要在onShow中更新登录状态
  onShow: function () {
    this.setData({
      hasLogin: wx.getStorageSync('isLogin')
    })
  },
 /**
  * 点击事件原来需要做的操作
  * 登录成功后自动继续做这个操作
  */
  jumpToLogsPage: function(data) {
    console.log("data:", data)
    wx.navigateTo({
      url: '../logs/logs'
    })
  }

下面是具体实例:

  • 第一次未登录,点击登录成功后自动跳转
  • 第二次点击时已经登录了,所以直接跳转

     

    login-view.gif

需要完整源码请上GitHub --> zy-login-view 获取


作者:韦弦Zhy
链接:https://www.jianshu.com/p/1abbf8655425

关于Fundebug

Fundebug专注于JavaScript、微信小程序、微信小游戏、支付宝小程序、React Native、Node.js和Java实时BUG监控。 自从2016年双十一正式上线,Fundebug累计处理了9亿+错误事件,得到了Google、360、金山软件、百姓网等众多知名用户的认可。欢迎免费试用!


鲜花

握手

雷人

路过

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

请发表评论

全部评论

专题导读
上一篇:
推荐几个适用的微信小程序发布时间:2022-07-18
下一篇:
百度小程序自定义组件component发布时间: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