微信小程序登录界面的实现

这篇具有很好参考价值的文章主要介绍了微信小程序登录界面的实现。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

首先是未登录时的界面,提示用户登录之后使用全部的功能。

用户点击登录,调用API拿到用户的信息并在页面中显示出来,同时将用户的信息保存在本地。向后端发送POST请求,拿到code,拿到token,并保存在本地,登录之后隐藏未登录的界面,显示登录后的界面。

点击退出登录之后,重置一些数据,隐藏登陆后的界面,显示未登录时的界面

WXML

<view class="backGround"></view>
<!-- 未登录时的页面 -->
<block wx:if="{{hiddenBlean1}}">
  <view class="container-out">
      <view class="faceOut"></view>
      <view class="textout">
          <view class="word1">
               <text>未登录</text>
          </view>
          <view class="word2">
               <text>请点击登陆后使用全部功能</text>
          </view>
      </view>
  </view>
  <button bindtap="getUersProfile" class="btn">登录</button>
</block>
<!-- 登陆后的页面 -->
<block wx:if="{{hiddenBlean2}}">
<!-- 头像,用户名,招呼 -->
  <view class="container-in">
    <image src="{{avatarUrl}}" class="touxiang"></image>
    <view class="wenZi">
       <view class="word3">
          {{nickName}}
       </view>
       <view class="word4">
          Hi
       </view>
    </view>
  </view>
  <view class="loginOut" bindtap="loginOut">
       <button>退出登录</button>
  </view>
</block>

WXSS 

page {
  background-color: #ededed;
}

.backGround {
  width: 100%;
  height: 490rpx;
  background-color: #2b4b6b;
  border-radius: 0 0 25rpx 25rpx;
  overflow: hidden;
}

.btn {
  width: 400rpx;
  height: 100rpx;
  margin-top: 200rpx;
  border-radius: 20rpx;
  box-shadow: 1rpx 0rpx 10rpx 1rpx rgba(0, 0, 0, .2);
  background-color: #05c160;
  color: white;
  font-size: large;
}

.btn:active {
   background-color: teal;
}

.container-out {
  display: flex;
  align-items: center;
  margin:-100rpx auto;
  width: 650rpx;
  height: 250rpx;
  box-shadow: 1rpx 1rpx 19rpx 1rpx rgba(0, 0, 0, .03);
  border-radius: 20rpx;
  background-color: rgb(255, 255, 255);
}

.faceOut {
  display: inline-block;
  width: 210rpx;
  height: 210rpx;
  margin-left: 20rpx;
  border-radius: 20rpx;
  background-color: rgb(235, 230, 230);
}

.textout {
  display: inline-block;
  margin-left: 20rpx;
  width: 360rpx;
  height: 210rpx;
  /* background-color: salmon; */
}

.word1 {
  margin-left: 20rpx;
  font-size: 50rpx;
}

.word2 {
  margin-top: 20rpx;
  margin-left: 20rpx;
  font-size: 25rpx;
}

.container-in {
  display: flex;
  margin:-100rpx auto;
  margin-bottom: 0;
  width: 650rpx;
  height: 250rpx;
  box-shadow: 1rpx 0rpx 10rpx 1rpx rgba(0, 0, 0, .02); 
  border-radius: 20rpx;
  background-color: rgb(255, 255, 255);
}

.touxiang {
  display: inline-block;
  width: 210rpx;
  height: 210rpx;
  margin-top: 20rpx;
  margin-left: 20rpx;
  border-radius: 100rpx;
  border: 1rpx solidrgb(124, 121, 121)k;
}

.wenZi {
  display: inline-block;
  width: 300rpx;
  height: 210rpx;
  margin-top: 20rpx;
  /* background-color: aqua; */
  margin-left: 20rpx;
}

.word3 {
  font-size: 40rpx;
  margin-left: 20rpx;
  margin-top: 50rpx;
}

.word4 {
  font-size: 25rpx;
  color: gray;
  line-height: 35rpx;
  margin-left: 20rpx;
  margin-top: 10rpx;
}

.loginOut {
  margin-top: 100rpx;
}

JSON

{
  "usingComponents": {},
  "navigationStyle":"custom",
  "navigationBarTextStyle":"black",
  "backgroundColor": "#000000"
}

 JS


Page({
  data: {
       hiddenBlean1:true,
       hiddenBlean2:false,
       userInfo:'',//用户信息
       nickName:'',//用户姓名
       avatarUrl:'',//用户头像地址
       m:0,//用户的登录状态
  }, 
//退出登录
  loginOut() {
    this.setData({
      userInfo:'',
      hiddenBlean1:true,
      hiddenBlean2:false,
      m:0
    })
    wx.request({
      url: '',
      method:'POST',
      header: {
        'Content-Type':'application/json'
      },
      success:res=> {
        console.log(res)
      }
    })
    wx.setStorageSync('user', null),
    wx.showToast({
      title: '已退出登录',
    })
  },

//获取用户信息
  getUersProfile:function() {
    if(this.data.m==0) {
      wx.getUserProfile({
        desc: '登陆后使用全部功能',
        success:(res)=> {
          let user = res.userInfo
          console.log('获取成功',res)
          wx.setStorage({
            data: res.userInfo,
            key:'userInfo',          
          });

          wx.login({//获取code向后端发送并请求token
            success(res) {
              console.log(res.code)
              let code = res.code            
              wx.request({
                url: '' + res.code,
                method:'POST',
                header: {
                    'Content-Type':'application/json'
                },             
                success:res=>{
                   console.log(res)
                   console.log(res.data.data.token)
                   wx.setStorageSync('token', res.data.data.token)
                }
              })
            }
          });         
        console.log('用户信息',res.userInfo),
        console.log(res.userInfo.nickName),
          this.setData({
            m:1,
            nickName : res.userInfo.nickName,
            avatarUrl: res.userInfo.avatarUrl,
            hiddenBlean2:true,
            hiddenBlean1:false
          })
          wx.showToast({
            title: '登陆成功',
          })
          wx.hideToast()
          this.onShow();
        },
        fail:(res)=> {
          console.log('授权失败',res)
        }
      })
    }
    else {
      wx.showToast({
        title: '您已经登录了',
      })
    }
}
})

效果 

微信小程序登录页面,微信小程序,微信小程序微信小程序登录页面,微信小程序,微信小程序

 微信小程序登录页面,微信小程序,微信小程序微信小程序登录页面,微信小程序,微信小程序文章来源地址https://www.toymoban.com/news/detail-521636.html

到了这里,关于微信小程序登录界面的实现的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 微信小程序登录注册页面代码

    以下是一个简单的微信小程序注册登录页面的代码示例: 上面代码中,index.wxml 文件定义了注册页面的视图,包括用户名、密码、确认密码的输入框以及提交按钮和一个跳转到登录页面的链接。index.js 文件定义了注册页面的逻辑,当用户点击提交按钮时会发送注册请求,并根

    2024年02月11日
    浏览(48)
  • 微信小程序授权登录,跳转页面后在跳回首页不用再次登录

           小程序授权登录要使用wx.getUserProfile,获得用户投头像后,做一些页面跳转功能,但是如果需要再次跳转首页的话,小程序就会有回到登录前的状态,这样体验感会很差。要想不用再次登录,也不难,只需要判断userInfo是否还存有信息就可以了。举个例子: 跳转后的

    2024年02月13日
    浏览(48)
  • uni-app 微信小程序之好看的ui登录页面(一)

    更多登录ui页面 uni-app 微信小程序之好看的ui登录页面(一) uni-app 微信小程序之好看的ui登录页面(二) uni-app 微信小程序之好看的ui登录页面(三) uni-app 微信小程序之好看的ui登录页面(四) uni-app 微信小程序之好看的ui登录页面(五)

    2024年02月04日
    浏览(59)
  • uni-app 微信小程序之好看的ui登录页面(二)

    更多登录ui页面 uni-app 微信小程序之好看的ui登录页面(一) uni-app 微信小程序之好看的ui登录页面(二) uni-app 微信小程序之好看的ui登录页面(三) uni-app 微信小程序之好看的ui登录页面(四) uni-app 微信小程序之好看的ui登录页面(五)

    2024年02月03日
    浏览(59)
  • uni-app 微信小程序之好看的ui登录页面(四)

    更多登录ui页面 uni-app 微信小程序之好看的ui登录页面(一) uni-app 微信小程序之好看的ui登录页面(二) uni-app 微信小程序之好看的ui登录页面(三) uni-app 微信小程序之好看的ui登录页面(四) uni-app 微信小程序之好看的ui登录页面(五)

    2024年02月04日
    浏览(46)
  • uni-app 微信小程序之好看的ui登录页面(五)

    更多登录ui页面 uni-app 微信小程序之好看的ui登录页面(一) uni-app 微信小程序之好看的ui登录页面(二) uni-app 微信小程序之好看的ui登录页面(三) uni-app 微信小程序之好看的ui登录页面(四) uni-app 微信小程序之好看的ui登录页面(五)

    2024年02月04日
    浏览(56)
  • uni-app 微信小程序之好看的ui登录页面(三)

    更多登录ui页面 uni-app 微信小程序之好看的ui登录页面(一) uni-app 微信小程序之好看的ui登录页面(二) uni-app 微信小程序之好看的ui登录页面(三) uni-app 微信小程序之好看的ui登录页面(四) uni-app 微信小程序之好看的ui登录页面(五)

    2024年01月15日
    浏览(57)
  • SpringCloud微服务实战——搭建企业级开发框架(五十三):微信小程序授权登录增加多租户可配置界面

      GitEgg框架集成weixin-java-miniapp工具包以实现微信小程序相关接口调用功能,weixin-java-miniapp底层支持多租户扩展。每个小程序都有唯一的appid,weixin-java-miniapp的多租户实现并不是以租户标识TenantId来区分的,而是在接口调用时,传入appid,动态切换ThreadLocal的appid来实现多租户

    2024年02月15日
    浏览(51)
  • 【微信小程序】实现微信小程序登录(附源码)

    通过 点击登录按钮 , 调用微信接口 wx.getUserProfile拿到微信的个人信息,先 检查是否之前已经登录 ,若没登录则将拿到的个人信息调用后台的接口,把个人信息传给后台, 登录成功之后 把相关信息存储在app.globalData中共享给全局使用 (这里使用微信云开发作为后台,提前建

    2024年02月11日
    浏览(49)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包