微信小程序登录注册页面设计(小程序项目)

需求

在微信小程序设计并实现登录页面,并填写相关登录注册函数

实现效果

代码实现

html代码

<view class="top" style="border-bottom-style: none;background-color:#FF8C69;">
  <!-- <view class="back" bind:tap="back">
    <van-icon name="arrow-left" size="50rpx" />
  </view> -->
  <view class="pagetitle-container">
    <view class="pagetitle">登录.注册</view>
  </view>
</view>
<view class="top-box">
  <view>Hi</view>
  <view class="next-text">欢迎使用XXXX!</view>
</view>
<!-- 登录、注册 -->
<view class="center-box">
  <view class="nav">
    <view class="left {{current==1?'select':''}}" bindtap="click" data-code="1">
      <text>登录</text>
    </view>
    <view class="right {{current==0?'select':''}}" bindtap="click" data-code="0">
      <text>注册</text>
    </view>
  </view>
  <!-- 登录 -->
  <view class="input-box" hidden="{{current==0}}">
    <view class="wei-input">
      <text slot="icon" class="iconfontgh icon-shoujihao" mode="aspectFit"></text>
      <input class="input" name="phone" placeholder="请输入手机号" value="{{ phone }}" bindinput="bindPhone" />
    </view>
    <view type="text" style="width: 1rpx;height: 1rpx;overflow: hidden;">
      <input></input>
    </view>
    <view class="wei-input">
      <text slot="icon" class="iconfontgh icon-mima" mode="aspectFit"></text>
      <!--index.wxml-->
      <view>
        <input class="input" style="width: 100%;" id="pwdInput" placeholder="请输入密码" password="{{pwdType=='password'}}" name="password" value="{{ password }}" bindinput="bindPwd" />
      </view>
      <view class="eye-btn">
        <block wx:if="{{!pwdView}}">
          <van-icon bindtap="togglePwdView" name="eye-o" />
        </block>
        <block wx:elif="{{pwdView}}">
          <van-icon bindtap="togglePwdView" name="closed-eye" />
        </block>
      </view>
    </view>
    <view class="checkbox-container">
      <checkbox-group bindchange="onChange">
        <checkbox value="1" checked="{{checked}}"></checkbox>
        <label class="checkbox-label" for="check">记住密码</label>
      </checkbox-group>
    </view>
  </view>
  <!-- 注册 -->
  <view class="input-box" hidden="{{current==1}}">
    <view class="wei-input">
      <text slot="icon" class="iconfontgh icon-shoujihao" mode="aspectFit"></text>
      <input class="input" name="registerPhone" placeholder="请输入您的手机号" value="{{registerPhone}}" bindinput="bindRegisterPhone" />
    </view>
    <view class="wei-input">
      <text slot="icon" class="iconfontgh icon-touxiang" mode="aspectFit"></text>
      <input class="input" name="name" placeholder="请输入您的姓名" value="{{name}}" bindinput="bindName" />
    </view>
    <view class="wei-input">
      <text slot="icon" class="iconfontgh icon-gonghao" mode="aspectFit"></text>
      <input class="input" name="oa_num" placeholder="请输入您的工号" value="{{oa_num}}" bindinput="bindOaNum" />
    </view>
    <view class="wei-input">
      <text slot="icon" class="iconfontgh icon-bumenguanli" mode="aspectFit"></text>
      <input class="input" name="department" placeholder="请输入您的部门" value="{{section}}" bindinput="bindDepartment" />
    </view>
    <view class="bottom-box">
      注册
    </view>
  </view>
  <view class="sumbit-btn">
    <button bindtap="handleButtonClick" class="button" style="background-color: #F9BB8E;font-size: 30rpx;" type="primary">立即{{current==1?'登录':'注册'}}</button>
  </view>
</view>
<!-- 重影 -->
<view class="shadow shadow-1"></view>
<view class="shadow shadow-2"></view>
<!-- 说明 -->

css代码

/*  */
page {
  height: 100%;
  background-color: white;
  margin: 0px;
  padding: 0px;
}
.top {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  background-color: #fff; /* 可以根据需要设置背景色 */
  z-index: 1000; /* 确保它覆盖在其他元素之上 */
  padding: 0 20rpx; /* 添加左右内边距以便于阅读 */
  height: 180rpx; /* 设置固定高度 */
  border-bottom-width: 1rpx;
  border-bottom-style: solid;
}
.pagetitle-container {
  display: flex;
  align-items: center;
  justify-content: center;
  margin: auto;
  background-color: #FF8C69;
}
.pagetitle {
  font-size: 30rpx;
  font-weight: bold;
  margin-bottom: -80rpx;
  
}
/* 顶部背景 */
.top-box {
  margin-top: 180rpx;
  height: 30%;
  background-image: linear-gradient(#FF8C69,#F9BB8E);
  padding: 30rpx;
  color: white;
  font-weight: bold;
}

/* index.wxss */
.eye-btn {
  right: 20rpx;
  margin-top: 10rpx;
  position: absolute;
}

.next-text {
  margin-top: 15rpx;
}

/* 内容 */
.center-box {
  background-color: white;
  margin: -20% 20rpx 0rpx 20rpx;
  padding: 25rpx;
  border-radius: 15rpx;
  -webkit-filter: drop-shadow(0 0 8rpx #F9BB8E);
  filter: drop-shadow(0 0 8rpx #FF8C69);
}

/* 导航 */
.nav {
  display: flex;
  text-align: center;
  font-size: 32rpx;
  margin-bottom: 8%;
}

.left {
  flex: 1;
  font-weight: bold;
}

.right {
  flex: 1;
  font-weight: bold;
}

.select {
  font-weight: bold;
  color: #F9BB8E;
}

.select text {
  padding-bottom: 5rpx;
  border-bottom-left-radius: 10rpx;
  border-bottom-right-radius: 10rpx;
  border-bottom: 5rpx solid #F9BB8E;
}

.wei-input {
  position: relative;
  display: flex;
  flex-direction: row;
  align-items: center;
  margin-top: 40rpx;
  padding-bottom: 20rpx;
  border-bottom: 1rpx solid #f1f1f1;
}

.input-box {
  margin: 20rpx;
}

.input {
  padding-left: 20rpx;
  font-size: 30rpx;
}

.input-code {
  position: absolute;
  right: 40rpx;
  font-size: 26rpx;
  padding: 10rpx 15rpx;
  color: white;
  background-color: #FF8C69;
  border-radius: 10rpx;
}


.checkbox-container {
  font-size: 26rpx;
  color: #FF8C69;
  margin-top: 20rpx;
  text-align: right;
  display: flex;
  align-items: center; /* 垂直居中对齐 */
}
.wx-checkbox-input {
  width: 33rpx !important;
  height: 33rpx !important;
  border: 2rpx solid #FF8C69 !important;
}
.wx-checkbox-input-checked{
  width: 33rpx !important;
  height: 33rpx !important;
  border: 2rpx solid #FF8C69 !important;
  color: #FF8C69 !important;
}

.sumbit-btn {
  margin: 6% 30rpx 30rpx 30rpx;
}

/* 重影 */
.shadow {
  box-shadow: 0rpx 0rpx 10rpx 0rpx #FF8C69;
  border-radius: 25rpx;
  background-color: white;
}

.shadow-1 {
  height: 40rpx;
  margin: -20rpx 50rpx 0 50rpx;
}

.shadow-2 {
  position: relative;
  z-index: -888;
  height: 50rpx;
  margin: -30rpx 80rpx 0 80rpx;
}

/* 最底部 */
.bottom-box {
  bottom: 5rpx;
  width: 100%;
  font-size: 24rpx;
  color: gray;
  display: flex;
  justify-content: center;
}

/* 弹窗背景蒙层 */
.modal-overlay {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: rgba(0, 0, 0, 0.6);
  display: flex;
  justify-content: center;
  align-items: center;
}

/* 弹窗内容 */
.modal {
  background-color: #FFFFFF;
  width: 80%; /* 弹窗宽度,根据实际需要调整 */
  max-width: 600px; /* 最大宽度限制 */
  border-radius: 10px;
  padding: 20px;
  box-shadow: 0 4px 6px rgba(0, 0, 0, 0.5);
  display: flex;
  flex-direction: column;
  align-items: center;
}

js代码

const util = require('../../utils/util.js'),
app = getApp();
Page({

  /**
   * 页面的初始数据
   */


  data: {
    "pwdType": 'password', // 默认为密码类型
    "pwdView": true, // 控制是否显示密码
    "current": 1,
    "codeText": '获取验证码',
    "counting": false,
    "phone": "",
    "password": "",
    checked: false,
    modalVisible: false,
    is_login: false

  },
  //注册功能
  bindName: function (e) {
    this.setData({
      name: e.detail.value
    });
  },
  bindRegisterPhone: function (e) {
    this.setData({
      registerPhone: e.detail.value
    });
  },
  bindOaNum: function (e) {
    this.setData({
      oa_num: e.detail.value
    });
  },

  bindDepartment: function (e) {
    this.setData({
      department: e.detail.value
    });
  },
  // 登陆功能
  bindPhone: function (e) {
    this.setData({
      phone: e.detail.value
    });
  },

  bindPwd: function (e) {
    this.setData({
      password: e.detail.value
    });
  },
  register: function () {
    if (!this.data.registerPhone) {
      wx.showToast({
        icon: 'none',
        title: '请填写手机',
      })
    } else if (!this.data.name) {
      wx.showToast({
        icon: 'none',
        title: '请填写名称',
      })
    } else if (!this.data.oa_num) {
      wx.showToast({
        icon: 'none',
        title: '请填写工号',
      })
    } else if (!this.data.department) {
      wx.showToast({
        icon: 'none',
        title: '请填写部门',
      })
    } else {
      wx.cloud.init()
      wx.cloud.callContainer({XXXXXXXX}).then(res => {
        console.log(res)
        if (res.data.data == 1) {
          wx.showToast({
            title: '账号申请成功!',
            icon: 'success',
            duration: 2500
          })
        } else {
          wx.showToast({
            title: res.data.msg,
            icon: 'error',
            duration: 2500
          })
        }


      })
    }

  },

  create_login(e) {
    let user = e
    // console.log(user)
    if (!user.phone) {
      wx.showToast({
        icon: 'none',
        title: '请填写手机',
      })
    } else if (!user.password) {
      wx.showToast({
        icon: 'none',
        title: '请填写密码',
      })
    } else {
      wx.cloud.init()
      wx.cloud.callContainer({XXXXX})
        .then(res => {
          console.log('获取登录结果', res.data)
          let msg = res.data.msg
          if (msg == "登录成功") {

            console.log(user.phone)
            wx.setStorage({ key: 'currentUser', data: user.phone, encrypt: true })
            var app = getApp();
            app.globalData.userforPerson = user.phone;
            

            var logs = (wx.getStorageSync('logs') || []).map(log => {
              return {
                date: util.formatTime(new Date(log)),
                timeStamp: log
              }
            })
            // console.log(logs[0])
            wx.setStorage({
              key: 'LastLoginTime',
              data: logs[0],
            });
            wx.setStorage({
              key: 'passwordIsEdit',
              data: res.data.password_is_edit,
            });
            wx.setStorage({
              key: 'currentUser',
              data: user.phone,
              encrypt: true
            });
            wx.setStorage({
              key: 'currentUserPassword',
              data: user.password,
              encrypt: true
            });
            wx.switchTab({
              url: "/pages/home/home",
              success: function (res) {
                var page = getCurrentPages().pop();
                if (page == undefined || page == null) return;
                page.onShow();
                console.log('跳转成功')// success
              },
              fail: function (res) {
                console.log('跳转失败')  // fail
              },
              complete: function (res) {
                console.log('跳转页面完成') // complete
              }
            })
          } else {
            wx.showToast({
              title: res.data.msg,
              icon: "error"
            })
          }
        })
        .catch(res => {
          console.log('获取登录结果失败', res)
        })
    }
  },
  handleButtonClick() {
    //current==1登录
    if (this.data.current == 1) {
      wx.setStorage({
        key: 'RememberPassword',
        encrypt: true,
        data: this.data.checked,
      })
      this.create_login({
        "phone": this.data.phone,
        "password": this.data.password
      })
    }
    //current==1注册
    if (this.data.current == 0) {
      this.register()
    }


  },

  ToRegister() {
    wx.navigateTo({
      url: '/pages/register/register',
    })
  },
  // 登陆注册监听
  click(e) {
    let index = e.currentTarget.dataset.code;
    this.setData({
      current: index
    })
  },
  
  togglePwdView: function () {
    this.setData({
      pwdType: this.data.pwdType === 'password' ? 'text' : 'password',
      pwdView: !this.data.pwdView,
    });
  },
  onChange(e) {
    this.setData({
      checked: e.detail.value.includes('1')
    })
  },

  CloseActivity(){
  },
  /**
   * 生命周期函数--监听页面加载
   */
  onLoad(options) {
  },
  /**
   * 生命周期函数--监听页面初次渲染完成
   */
  onReady() {

  },

  /**
   * 生命周期函数--监听页面显示
   */
  onShow() {

  },

  /**
   * 生命周期函数--监听页面隐藏
   */
  onHide() {

  },

  /**
   * 生命周期函数--监听页面卸载
   */
  onUnload() {

  },

  /**
   * 页面相关事件处理函数--监听用户下拉动作
   */
  onPullDownRefresh() {

  },

  /**
   * 页面上拉触底事件的处理函数
   */
  onReachBottom() {

  },

  /**
   * 用户点击右上角分享
   */
  onShareAppMessage() {

  },

  showModal: function() {
    this.setData({
      modalVisible: true
    });
  },
  hideModal: function() {
    this.setData({
      modalVisible: false
    });
  },
    
    });


  

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/920280.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

神经网络(系统性学习三):多层感知机(MLP)

相关文章&#xff1a; 神经网络中常用的激活函数 神经网络&#xff08;系统性学习一&#xff09;&#xff1a;入门篇 神经网络&#xff08;系统性学习二&#xff09;&#xff1a;单层神经网络&#xff08;感知机&#xff09; 多层感知机&#xff08;MLP&#xff09; 多层感…

Android 14 screenrecord录制视频失败的原因分析

文章目录 1. 权限问题2. 存储空间不足3. 命令被中断4. 目标路径问题5. Android 14 的新限制6. 文件系统同步问题7. 录制失败检查步骤总结&#xff1a; 在 Android 14 系统上&#xff0c;使用 screenrecord 命令录制视频后&#xff0c;生成的文件大小为 0&#xff0c;可能的原因…

Uniapp 简单配置鸿蒙

Uniapp 简单配置鸿蒙 前言下载并配置鸿蒙IDEHbuilder X 配置基本的信息生成相关证书登录官网获取证书IDE配置证书添加调试设备可能出现的问题前言 如今鸿蒙的盛起,作为多端开发的代表也是开始兼容鸿蒙应用的开发,接下来我将介绍如何在uniapp中配置鸿蒙。 注意:hbuilder X的…

git使用(一)

git使用&#xff08;一&#xff09; 为什么学习git?两种版本控制系统在github上创建一个仓库&#xff08;repository&#xff09;windows上配置git环境在Linux上配置git环境 为什么学习git? 代码写了好久不小心删了&#xff0c;可以使用git防止&#xff0c;每写一部分代码通…

C# 数据结构之【树】C#树

以二叉树为例进行演示。二叉树每个节点最多有两个子节点。 1. 新建二叉树节点模型 using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks;namespace DataStructure {class TreeNode{public int Data { get;…

HarmonyOs鸿蒙开发实战(20)=>一文学会基础使用组件导航Navigation

敲黑板&#xff0c;以下是重点技巧。文章末尾有实战项目效果截图及代码截图可参考 1.概要 Navigation是路由导航的根视图容器Navigation组件主要包含​导航页&#xff08;NavBar&#xff09;和子页&#xff08;NavDestination&#xff09;&#xff0c;导航页不存在页面栈中&am…

python从入门到精通:pyspark实战分析

前言 spark&#xff1a;Apache Spark是用于大规模数据&#xff08;large-scala data&#xff09;处理的统一&#xff08;unified&#xff09;分析引擎。简单来说&#xff0c;Spark是一款分布式的计算框架&#xff0c;用于调度成本上千的服务器集群&#xff0c;计算TB、PB乃至E…

Ubuntu从入门到精通(二)远程和镜像源配置齐全

Ubuntu从入门到精通(二) 1 常见操作配置 1.1 英文语言配置 1.1.1 打开设置 1.1.2 设置语言为英文 1.1.3 重启生效 1.1.4 再次进入,选择更新名字 1.1.5 再次进入,发现已经变成了英文 1.2 输入法配置 1.3 rustdesk安装 1.3.1 Windows系统配置 登陆:https://github.com…

HTML5拖拽API学习 托拽排序和可托拽课程表

文章目录 前言拖拽API核心概念拖拽式使用流程例子注意事项综合例子&#x1f330; 可拖拽课程表拖拽排序 前言 前端拖拽功能让网页元素可以通过鼠标或触摸操作移动。HTML5 提供了标准的拖拽API&#xff0c;简化了拖放操作的实现。以下是拖拽API的基本使用指南&#xff1a; 拖拽…

华为Ensp模拟器配置OSPF路由协议

目录 简介 实验步骤 Pc配置 路由器配置 OSPF配置 交换机配置 简介 开放式最短路径优先 (OSPF) 协议深度解析 简介 开放式最短路径优先&#xff08;Open Shortest Path First, OSPF&#xff09;是一种内部网关协议&#xff08;IGP&#xff09;&#xff0c;用于在自治系统…

【最新鸿蒙应用开发】——合理使用自定义弹框

自定义弹窗选型 合理选择不同的系统能力实现弹窗&#xff0c;有利于提升应用开发效率&#xff0c;实现更好的功能需求&#xff0c;因此了解自定义弹窗的选型和差异非常重要。在应用开发中&#xff0c;为了选择出合适的弹窗选型&#xff0c;从使用场景上&#xff0c;需要重点关…

自动化爬虫Selenium

自动化爬虫Selenium 这篇文章, 我们将要学习自动化爬虫的知识啦。 目录 1.Selenium的基本操作 2.用Selenuim获取数据 3.当当网数据获取 4.实战 一、Selenium的基本操作 首先, 我们在使用Selenium之前, 需要做两件事情。第一件事情, 就是安装第三方库, 第二件事情, 就是…

开源可视化工具对比:JimuReport VS DataEase

在当今数据驱动的时代&#xff0c;高效的数据可视化工具成为企业洞察业务、做出决策的关键利器。那对于企业来讲如何选择BI产品呢&#xff1f; 在开源可视化工具的领域中&#xff0c;JimuReport和DataEase 以其独特的优势脱颖而出&#xff0c;究竟谁更胜一筹呢&#xff1f;让我…

Jenkins的环境部署

day22 回顾 Jenkins 简介 官网Jenkins Jenkins Build great things at any scale The leading open source automation server, Jenkins provides hundreds of plugins to support building, deploying and automating any project. 用来构建一切 其实就是用Java写的一个项目…

Ubuntu22.04配置强化学习环境及运行相关Demo

什么是强化学习 强化学习&#xff08;Reinforcement Learning&#xff0c;简称 RL&#xff09;是机器学习中的一个重要分支&#xff0c;属于一种基于试错机制的学习方法。它通过让智能体&#xff08;Agent&#xff09;与环境&#xff08;Environment&#xff09;进行交互&…

AI 写作(一):开启创作新纪元(1/10)

一、AI 写作&#xff1a;重塑创作格局 在当今数字化高速发展的时代&#xff0c;AI 写作正以惊人的速度重塑着创作格局。AI 写作在现代社会中占据着举足轻重的地位&#xff0c;发挥着不可替代的作用。 随着信息的爆炸式增长&#xff0c;人们对于内容的需求日益旺盛。AI 写作能够…

丹摩征文活动 | AI创新之路,DAMODEL助你一臂之力GPU

目录 前言—— DAMODEL&#xff08;丹摩智算&#xff09; 算力服务 直观的感受算力提供商的强大​ 平台功能介绍​ 镜像选择 云磁盘创建 总结 前言—— 只需轻点鼠标,开发者便可拥有属于自己的AI计算王国 - 从丰富的GPU实例选择,到高性能的云磁盘,再到预配置的深度学习…

echarts的图例换行并对齐

现状&#xff1a; 期望&#xff1a; 实现方式&#xff1a; 通过对legend的formatter和textStyle组合设置宽度来实现&#xff0c;代码如下 这里会出现一个问题&#xff0c;发现设置了width没有效果&#xff0c;刚开始以为是宽度给的不够&#xff0c;然后发现并不是&#xff0c…

go-zero(二) api语法和goctl应用

go-zero api语法和goctl应用 在实际开发中&#xff0c;我们更倾向于使用 goctl 来快速生成代码。 goctl 可以根据 api快速生成代码模板&#xff0c;包括模型、逻辑、处理器、路由等&#xff0c;大幅提高开发效率。 一、构建api demo 现在我们通过 goctl 创建一个最小化的 HT…

Windows Server 2022 Web1

载入靶机&#xff0c;看到相关描述&#xff1a; 进入虚拟机发现桌面有phpstudy和解题两个软件&#xff1a; 打开解题.exe&#xff0c;发现里面是一些问题&#xff0c;接下来就需要获取相关信息&#xff1a; 1、shell密码 2、IP地址 3、隐藏账户名称 4、挖矿程序的矿池域名 打…