uni-app开发小程序一键登录的实现方式?

<script setup lang="ts">
// import { postLoginWxMinAPI, postLoginWxMinSimpleAPI } from '@/services/login'
// import { useMemberStore } from '@/stores'
// import type { LoginResult } from '@/types/member'
import {
    onLoad } from '@dcloudio/uni-app'

// #ifdef MP-WEIXIN
// 获取 code 登录凭证
let code = ''
onLoad(async () => {
   
  const res = await wx.login()
  code = res.code
})

// 获取用户手机号码
const onGetphonenumber: UniHelper.ButtonOnGetphonenumber = async (ev) => {
   
  const {
    encryptedData, iv } = ev.detail
  const res = await postLoginWxMinAPI({
    code, encryptedData, iv })
  loginSuccess(res.result)
}
// #endif

// 模拟手机号码快捷登录(开发练习)
const onGetphonenumberSimple = async () => {
   
  const res = await postLoginWxMinSimpleAPI('13123456789')
  loginSuccess(res.result)
}

const loginSuccess = (profile: LoginResult) => {
   
  // 保存会员信息
  const memberStore = useMemberStore()
  memberStore.setProfile(profile)
  // 成功提示
  uni.showToast({
    icon: 'success', title: '登录成功' })
  setTimeout(() => {
   
    // 页面跳转
    // uni.switchTab({ url: '/pages/my/my' })
    uni.navigateBack()
  }, 500)
}
</script>

<template>
  <view class="viewport">
    <view class="logo">
      <image
        src="https://pcapi-xiaotuxian-front-devtest.itheima.net/miniapp/images/logo_icon.png"
      ></image>
    </view>
    <view class="login">
      <!-- 网页端表单登录 -->
      <!-- #ifdef H5 -->
      <input class="input" type="text" placeholder="请输入用户名/手机号码" />
      <input class="input" type="text" password placeholder="请输入密码" />
      <button class="button phone">登录</button>
      <!-- #endif -->

      <!-- 小程序端授权登录 -->
      <!-- #ifdef MP-WEIXIN -->
      <button class="button phone" open-type="getPhoneNumber" @getphonenumber="onGetphonenumber">
        <text class="icon icon-phone"></text>
        手机号快捷登录
      </button>
      <!-- #endif -->
      <view class="extra">
        <view class="caption">
          <text>其他登录方式</text>
        </view>
        <view class="options">
          <!-- 通用模拟登录 -->
          <button @tap="onGetphonenumberSimple">
            <text class="icon icon-phone">模拟快捷登录</text>
          </button>
        </view>
      </view>
      <view class="tips">登录/注册即视为你同意《服务条款》和《小兔鲜儿隐私协议》</view>
    </view>
  </view>
</template>

<style lang="scss">
page {
   
  height: 100%;
}

.viewport {
   
  display: flex;
  flex-direction: column;
  height: 100%;
  padding: 20rpx 40rpx;
}

.logo {
   
  flex: 1;
  text-align: center;
  image {
   
    width: 220rpx;
    height: 220rpx;
    margin-top: 15vh;
  }
}

.login {
   
  display: flex;
  flex-direction: column;
  height: 60vh;
  padding: 40rpx 20rpx 20rpx;

  .input {
   
    width: 100%;
    height: 80rpx;
    font-size: 28rpx;
    border-radius: 72rpx;
    border: 1px solid #ddd;
    padding-left: 30rpx;
    margin-bottom: 20rpx;
  }

  .button {
   
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 80rpx;
    font-size: 28rpx;
    border-radius: 72rpx;
    color: #fff;
    .icon {
   
      font-size: 40rpx;
      margin-right: 6rpx;
    }
  }

  .phone {
   
    background-color: #28bb9c;
  }

  .wechat {
   
    background-color: #06c05f;
  }

  .extra {
   
    flex: 1;
    padding: 70rpx 70rpx 0;
    .caption {
   
      width: 440rpx;
      line-height: 1;
      border-top: 1rpx solid #ddd;
      font-size: 26rpx;
      color: #999;
      position: relative;
      text {
   
        transform: translate(-40%);
        background-color: #fff;
        position: absolute;
        top: -12rpx;
        left: 50%;
      }
    }

    .options {
   
      display: flex;
      justify-content: center;
      align-items: center;
      margin-top: 70rpx;
      button {
   
        padding: 0;
        background-color: transparent;
        &::after {
   
          border: none;
        }
      }
    }

    .icon {
   
      font-size: 24rpx;
      color: #444;
      display: flex;
      flex-direction: column;
      align-items: center;

      &::before {
   
        display: flex;
        align-items: center;
        justify-content: center;
        width: 80rpx;
        height: 80rpx;
        margin-bottom: 6rpx;
        font-size: 40rpx;
        border: 1rpx solid #444;
        border-radius: 50%;
      }
    }
    .icon-weixin::before {
   
      border-color: #06c05f;
      color: #06c05f;
    }
  }
}

.tips {
   
  position: absolute;
  bottom: 80rpx;
  left: 20rpx;
  right: 20rpx;
  font-size: 22rpx;
  color: #999;
  text-align: center;
}
</style>

在这里插入图片描述

最近更新

  1. TCP协议是安全的吗?

    2023-12-28 14:54:03       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2023-12-28 14:54:03       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2023-12-28 14:54:03       19 阅读
  4. 通过文章id递归查询所有评论(xml)

    2023-12-28 14:54:03       20 阅读

热门阅读

  1. 文件&IO

    文件&IO

    2023-12-28 14:54:03      36 阅读
  2. Flutter 官方状态管理 Provider基本使用

    2023-12-28 14:54:03       40 阅读
  3. 我的创作纪念日:感恩、感谢、感激!

    2023-12-28 14:54:03       43 阅读
  4. centos 安装 vsCode

    2023-12-28 14:54:03       36 阅读
  5. 激活函数:神经网络的生命之花

    2023-12-28 14:54:03       33 阅读
  6. 力扣:135. 分发糖果(贪心)

    2023-12-28 14:54:03       35 阅读
  7. Microsoft Edge 浏览器可能遇到的问题,和解决方法

    2023-12-28 14:54:03       48 阅读
  8. ansible 加密

    2023-12-28 14:54:03       39 阅读
  9. CentOS 8 安装指定版本ansible

    2023-12-28 14:54:03       37 阅读
  10. 使用aspose.Words更新表格列宽

    2023-12-28 14:54:03       31 阅读
  11. C++八股文 003:左值,右值

    2023-12-28 14:54:03       41 阅读