广告
返回顶部
首页 > 资讯 > 精选 >react如何实现登录和注册
  • 387
分享到

react如何实现登录和注册

2023-07-04 22:07:41 387人浏览 安东尼
摘要

这篇文章主要介绍了React如何实现登录和注册的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇react如何实现登录和注册文章都会有所收获,下面我们一起来看看吧。react实现登录和注册的方法:1、搭建样式组件;

这篇文章主要介绍了React如何实现登录和注册的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇react如何实现登录和注册文章都会有所收获,下面我们一起来看看吧。

react实现登录和注册的方法:1、搭建样式组件;2、创建登录注册页面的基础路由组件,代码如“import React,{Component} from 'react';import{PhoneLogin}from '... {render(){...}”;3、展示登录注册路由;4、连接数据库实现登录注册代码;5、通过判断本地存储来确定用户是否登录过,点击登录时进行判断即可。

react简单实现登录注册逻辑(localStorage模拟实现、数据库连接并通过查询数据库实现)

1、搭建样式组件

import styled from 'styled-components';export const MineContainer = styled.div`
  flex:1;
`export const PhoneLogin =styled.div`
  padding:10px;
  input{
     margin:3px;
  }

`export const UserReGISter = styled.div`
  padding:10px;
  input{
     margin:3px;
  }
`

localStorage模拟实现

2、登录注册页面的基础路由组件

import React ,{Component} from 'react';import {PhoneLogin} from './MineStyleComponent'class Login extends Component {
  render(){
     return(
        <PhoneLogin>
           手机号:<input type="text"/><br/>
           验证码:<input type="passWord"/><br/>
           <button>登录</button>
        </PhoneLogin>
     )
  }}export default Login;==========================================================================================import React ,{Component} from 'react';import {UserRegister} from './MineStyleComponent'class Register extends Component {
  render(){
     return(
        <UserRegister>
           手机号:<input type="text"/><br/>
           密码:<input type= "password" /><br/>
           验证码:<input type="password"/><br/>
           <button>登录</button>
        </UserRegister>
     )
  }}export default Register;

3、登录注册路由的展示

import React, { Component} from 'react';import {MineContainer} from './MineStyleComponent'import Login from './Login';import Register from './register';import {Route} from 'react-router-dom'class Mine extends Component {

  constructor(){
     super()
     this.state={
        loginFlag:false,//通过开关切换登录方式
     }
  }

  check = ()=>{//通过编程导航进行两个路由的切换

     if(this.state.loginFlag){
        this.props.history.push('/mine/register')
     }else{
        this.props.history.push('/mine/login')
     }

     this.setState({
        loginFlag:!this.state.loginFlag,
     })

  }
 
  render(){
     const {loginFlag} = this.state      return (
        <MineContainer>
          <Route path = "/mine/login" component = { Login }></Route>
          <Route path = "/mine/register" component = { Register }></Route>
          <button onClick = {this.check} > { loginFlag?'用户名登录':'短信验证登录'} </button>
        </MineContainer>
     )
  }}export default Mine;

react如何实现登录和注册

4、利用本地数据存取简单实现一下逻辑过程。

本地存储一个用户写法

import React ,{Component} from 'react';import {UserRegister} from './MineStyleComponent'class Register extends Component {

  //本地存储一个账户的模拟登录注册写法
  //逻辑:通过判断本地存储,来确定用户是否登录过,点击登陆时进行判断

  LoginClick = () =>{

     const username = this.users.value;
     const password = this.password.value;
     let  ls_users = localStorage.getItem('users');

     if(ls_users){
        //如果ls_users存在证明已有用户注册,判断密码,用户名是否正确
        ls_users = JSON.parse(ls_users)
       
        if(ls_users.username===username&&ls_users.password===password){
           alert('登录成功')
           this.props.history.push('/home')
        }else{
           alert('用户名或登录密码输入错误')
        }

     }else{
        //没有用户注册,直接保存到本地存储
        localStorage.setItem('users',jsON.stringify({username,password}))
        this.props.history.push('/home')
     }
  }


  render(){
     return(
        <UserRegister>
           用户名:<input type="text" ref= {el=>this.users=el} /><br/>
           密码:<input type= "password"  ref= {el=>this.password=el} /><br/>
           验证码:<input type="text"/><br/>
           <button onClick= {this.LoginClick} > 登录</button>
        </UserRegister>
     )
  }}export default Register;

localStorage中存储多个用户写法

import React ,{Component} from 'react';import {UserRegister} from './MineStyleComponent'class Register extends Component {

  //本地存储一个账户的模拟登录注册写法
  //逻辑:通过判断本地存储,来确定用户是否登录过,点击登陆时进行判断

  LoginClick = () =>{
     let obj = [];
     const username = this.users.value;
     const password = this.password.value;
     let  ls_users = localStorage.getItem('users');

     if(ls_users){
        //如果ls_users存在证明已有至少用户注册,
        obj = JSON.parse(ls_users)
        console.log(obj)
       
        //对本地存储数据进行便利与输入值对比
        let fg = obj.some (item => {
           if(item.username===username) return true//用户名已存在
        })

        if(fg){//fg为真找到用户名,接下里对密码判断
           //对存储数据遍历,比对用户名名与密码
           let f=false
           obj.map(item => {
              if(item.username===username&&item.password===password){
                 f=true;
                 return f;
              }    
           })
           if(f){//查询正确可以正常登录
              alert('登录成功')
              this.props.history.push('/home')
           }else{
              alert('密码错误')
           }

        }else{//没找到对将用户保存到本地,进行自动注册
           obj.push({username,password});
           localStorage.setItem('users',JSON.stringify(obj))
           this.props.history.push('/home')
        }
       
     }else{
        //没有用户注册,直接保存到本地存储
        obj.push({username,password})
        localStorage.setItem('users',JSON.stringify(obj))
        this.props.history.push('/home')
     }
  }


  render(){
     return(
        <UserRegister>
           用户名:<input type="text" ref= {el=>this.users=el} /><br/>
           密码:<input type= "password"  ref= {el=>this.password=el} /><br/>
           验证码:<input type="text"/><br/>
           <button onClick= {this.LoginClick} > 登录</button>
        </UserRegister>
     )
  }}export default Register;

连接数据库实现登陆注册代码

1、数据库操作代码

const { userSchema } = require('./schema');const { userModel } = require ('./module');//连接数据库const connect = require ('./connect');connect.init();//数据库操作const db = {
  user: {
     add(data){//数据添加
        const user = new userModel(data)
        user.save()
     },

     query(){//数据库查询,通过promise异步函数将结果返回出去
        return new Promise( (resolve,reject)=>{
           userModel.find( {},(err,docs) => {//查询数据库所有
              if(err) console.log(err)
              resolve(docs)//将查询结果返回出去
           })
        })
     }

  }}module.exports = {
  user: db.user}
2、服务端路由代码(nodejs中express搭建的服务端)

//打造用户信息接口const express = require ('express');const router = express.Router();const {user} = require ('../db');//打造restful接口,不同接口暴露不同功能人router.route('/userInfo')    .post( async (req,res,next) => {                const { userName, pass} = req.body      const result = await user.query()      //判断请求与数据库数据,在遍历前需要判断后台查询是否为空值      var f =result && result.some( item => {         if( item.userName === userName ) return true      })      if(f){//证明用户名存在,需要判断密码是否正确            let passFlag = result&&result.some( (item) => {               if(item.userName===userName&&item.pass===pass){                  return true               }         });         if(passFlag){//密码正确,登录成功               res.render('user',{                       data:JSON.stringify({                     info:'登录成功',                     status:2                  })               })         }else{//密码错误               res.render('user',{                       data:JSON.stringify({                     info:'用户名已存在或用户密码错误',                     status:0                  })               })         }      }else{//用户不存在,直接存入数据库,注册         user.add({...req.body})         res.render('user',{                 data:JSON.stringify({               info:'注册成功',               status:1            })         })      }     });module.exports = router//暴露路由接口

前台页面显示操作代码

import React ,{Component} from 'react';import {UserRegister} from './MineStyleComponent';import Http from '../../utils/http';class Register extends Component {

  //本地存储一个账户的模拟登录注册写法
  //逻辑:通过判断本地存储,来确定用户是否登录过,点击登陆时进行判断

 async LoginClick (){
     const username = this.users.value;
     const password = this.password.value;
     
     const params = new URLSearchParams()
     params.append('userName',username);
     params.append('pass',password)

     const res = await http({//调用封装好的axiOS数据请求方法
        url:'http://localhost:3000/userInfo',
        method:'POST',
        data:params      })
     if( res.data.status === 0 ){
        alert('用户名已经存在或是用户名密码错误')
      }else if ( res.data.status === 1){
        alert('注册成功')
      }else {
        this.props.history.push('/home')
        alert('登录成功')
      }

  }

  render(){
     return(
        <UserRegister>
           用户名:<input type="text" ref= {el=>this.users=el} /><br/>
           密码:<input type= "password"  ref= {el=>this.password=el} /><br/>
           验证码:<input type="text"/><br/>
           <button onClick= {this.LoginClick.bind(this)} > 登录</button>
        </UserRegister>
     )
  }}export default Register;

关于“react如何实现登录和注册”这篇文章的内容就介绍到这里,感谢各位的阅读!相信大家对“react如何实现登录和注册”知识都有一定的了解,大家如果还想学习更多知识,欢迎关注编程网精选频道。

--结束END--

本文标题: react如何实现登录和注册

本文链接: https://www.lsjlt.com/news/347969.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • react如何实现登录和注册
    这篇文章主要介绍了react如何实现登录和注册的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇react如何实现登录和注册文章都会有所收获,下面我们一起来看看吧。react实现登录和注册的方法:1、搭建样式组件;...
    99+
    2023-07-04
  • react怎么实现登录和注册
    本教程操作环境:Windows10系统、react18.0.0版、Dell G3电脑。react怎么实现登录和注册?react简单实现登录注册逻辑(localStorage模拟实现、数据库连接并通过查询数据库实现)1、搭建样式组件impor...
    99+
    2023-05-14
    React
  • Redis如何实现登录注册
    今天小编给大家分享一下Redis如何实现登录注册的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。1. 引言在传统的项目中,用户...
    99+
    2023-07-02
  • JavaScript如何实现web登录注册
    今天小编给大家分享一下JavaScript如何实现web登录注册的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。一、前端基础准...
    99+
    2023-07-06
  • springboot+VUE如何实现登录注册
    这篇文章主要介绍springboot+VUE如何实现登录注册,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!一、springBoot创建springBoot项目分为三个包,分别为controller,service, ...
    99+
    2023-06-15
  • Java实现登录和注册案例
    本文实例为大家分享了Java实现登录和注册的具体代码,供大家参考,具体内容如下 登录和注册案例的分析: 我们在完成一个需求时,需要面向对象,我们必须找到能完成某个功能的类,接着调用里...
    99+
    2022-11-13
  • 登录-注册网页实现
    re.php(登录的前端界面) 登录页面 .home{ text-align: center; font-wei...
    99+
    2023-08-31
    数据库 php 前端
  • springboot+VUE实现登录注册
    本文实例为大家分享了springboot+VUE实现登录注册的具体代码,供大家参考,具体内容如下 一、springBoot 创建springBoot项目 分为三个包,分别为contr...
    99+
    2022-11-12
  • android登录注册功能如何实现
    要实现Android的登录注册功能,你可以按照以下步骤进行操作:1. 创建一个布局文件来设计登录和注册界面。可以使用EditText...
    99+
    2023-10-20
    android
  • vue2.0+koa2+mongodb如何实现注册登录
    这篇文章将为大家详细讲解有关vue2.0+koa2+mongodb如何实现注册登录,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。前言前段时间和公司一个由技术转产品的同事探...
    99+
    2022-10-19
  • java如何实现注册登录系统
    本篇内容介绍了“java如何实现注册登录系统”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!1、创建菜单,注册,登录,退出2、注册模块:a) ...
    99+
    2023-06-30
  • QT如何实现用户登录注册
    本篇内容主要讲解“QT如何实现用户登录注册”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“QT如何实现用户登录注册”吧!具体代码如下#include "widget.h&quo...
    99+
    2023-07-02
  • Python如何实现注册登录功能
    这篇文章给大家分享的是有关Python如何实现注册登录功能的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。具体内容如下本文是用Python写一个注册登录功能,难度不大,很适合练手主要就是用列表和字典,以及逻辑判断用...
    99+
    2023-06-29
  • java如何实现登录注册界面
    这篇文章主要介绍“java如何实现登录注册界面”,在日常操作中,相信很多人在java如何实现登录注册界面问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”java如何实现登录注册界面”的疑惑有所帮助!接下来,请跟...
    99+
    2023-07-02
  • java注册登录功能如何实现
    Java注册登录功能可以通过以下步骤来实现:1. 创建数据库表:- 创建一个用户表,包括用户ID(主键),用户名,密码等字段。2. ...
    99+
    2023-08-11
    java
  • JSP实现简单的登录和注册
    JSP实现登录和注册(Map集合模拟数据库) 1、login.jsp2、 loginSelect.jsp3、register.jsp4、 RegisterSelect.jsp5、 index....
    99+
    2023-10-01
    java servlet 数据库
  • java+mysql实现登录和注册功能
    初学JAVA  EE,老师留下一小作业,用JAVA实现与服务器端交互,实现登录和注册功能,初学一种专业课很多老师都会留下一种让学生实现登录和注册的作业。 下面是记录的实现步...
    99+
    2022-11-13
  • java实现注册登录系统
    本文实例为大家分享了java实现注册登录系统的具体代码,供大家参考,具体内容如下 1、创建菜单,注册,登录,退出 2、注册模块: a) 通过键盘输入用户名,密码b) 保存用户名密码到...
    99+
    2022-11-13
  • node.js实现登录注册页面
    本文实例为大家分享了node.js登录注册页面展示的具体代码,供大家参考,具体内容如下 首先需要新建四个文件 一个服务器js 一个保存数据的txt 一个登陆、一个注册页面html 1、注册页面 <...
    99+
    2022-06-04
    页面 node js
  • Python实现注册登录功能
    用Python写个注册登录功能,供大家参考,具体内容如下 本文是用Python写一个注册登录功能,难度不大,很适合练手主要就是用列表和字典,以及逻辑判断用到的第3方库模块是time模...
    99+
    2022-11-13
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作