React后台管理系统-登录页面
登录页面
- <div className="col-md-4 col-md-offset-4">
- <div className="panel panel-default login-panel">
- <div className="panel-heading">欢迎登录 - MMALL管理系统</div>
- <div className="panel-body">
- <div>
- <div className="form-group">
- <input type="text"
- name="username"
- className="form-control"
- placeholder="请输入用户名"
- onKeyUp={e => this.onInputKeyUp(e)}
- onChange={e => this.onInputChange(e)}/>
- </div>
- <div className="form-group">
- <input type="password"
- name="password"
- className="form-control"
- placeholder="请输入密码"
- onKeyUp={e => this.onInputKeyUp(e)}
- onChange={e => this.onInputChange(e)}/>
- </div>
- <button className="btn btn-lg btn-primary btn-block"
- onClick={e => {this.onSubmit(e)}}>登录</button>
- </div>
- </div>
- </div>
- </div>
当用户名和密码发生改变的时候,设置onChange事件,重新设置state里边username和password的值
- this.state = {
- username: '',
- password: '',
- redirect: _mm.getUrlParam('redirect') || '/'
- }
- // 当用户名发生改变
- onInputChange(e){
- let inputValue = e.target.value,
- inputName = e.target.name;
- this.setState({
- [inputName] : inputValue
- });
- }
给输入框设置onKeyUp事件,监听输入框按下enter键的时候,提交登录数据
- onInputKeyUp(e){
- if(e.keyCode === 13){
- this.onSubmit();
- }
- }
提交表单数据,提交之前先验证表单数据,
- // 检查登录接口的数据是不是合法
- checkLoginInfo(loginInfo){
- let username = $.trim(loginInfo.username),
- password = $.trim(loginInfo.password);
- // 判断用户名为空
- if(typeof username !== 'string' || username.length ===0){
- return {
- status: false,
- msg: '用户名不能为空!'
- }
- }
- // 判断密码为空
- if(typeof password !== 'string' || password.length ===0){
- return {
- status: false,
- msg: '密码不能为空!'
- }
- }
- return {
- status : true,
- msg : '验证通过'
- }
- }
- onSubmit(){
- let loginInfo = {
- username : this.state.username,
- password : this.state.password
- },
- //验证表单
- checkResult = _user.checkLoginInfo(loginInfo);
- // 验证通过
- if(checkResult.status){
- _user.login(loginInfo).then((res) => {
- _mm.setStorage('userInfo', res);
- //console.log(this.state.redirect);
- this.props.history.push(this.state.redirect);
- }, (errMsg) => {
- _mm.errorTips(errMsg);
- });
- }
- // 验证不通过
- else{
- _mm.errorTips(checkResult.msg);
- }
- }
登录之后跳转地址this.sate.redirect= _mm.getUrlParam('redirect') || '/' , this.props.history.push(this.state.redirect);
- // 跳转登录
- doLogin(){
- //window.location.pathname url路径部分,端口后边,问号前边
- //例如 redirect="/user/index"
- window.location.href = '/login?redirect=' + window.location.pathname;
- // window.location.href = '/login?redirect=' + encodeURIComponent(window.location.pathname);
- }
- // 获取URL参数
- getUrlParam(name){
- //http://localhost:8086/login?redirect=/product/index
- // param=123¶m1=456
- let queryString = window.location.search.split('?')[1] || '',
- reg = new RegExp("(^|&)" + name + "=([^&]*)(&|$)"),
- result = queryString.match(reg);
- console.log(result);
- return result ? decodeURIComponent(result[2]) : null;
- }
React后台管理系统-登录页面的更多相关文章
- 我的第一个python web开发框架(14)——后台管理系统登录功能
接下来正式进入网站的功能开发.要完成后台管理系统登录功能,通过查看登录页面,我们可以了解到,我们需要编写验证码图片获取接口和登录处理接口,然后在登录页面的HTML上编写AJAX. 在进行接口开发之前, ...
- 《React后台管理系统实战 :一》:目录结构、引入antd、引入路由、写login页面、使用antd的form登录组件、form前台验证、高阶函数/组件
实战 上接,笔记:https://blog.csdn.net/u010132177/article/details/104150177 https://gitee.com/pasaulis/react ...
- 《React后台管理系统实战 :三》header组件:页面排版、天气请求接口及页面调用、时间格式化及使用定时器、退出函数
一.布局及排版 1.布局src/pages/admin/header/index.jsx import React,{Component} from 'react' import './header. ...
- 《React后台管理系统实战 :二》antd左导航:cmd批量创建子/目录、用antd进行页面布局、分离左导航为单独组件、子路由、动态写左导航、css样式相对陷阱
一.admin页面布局及路由创建 0)cmd批量创建目录及子目录 //创建各个目录,及charts和子目录bar md home category product role user charts\b ...
- 【共享单车】—— React后台管理系统开发手记:主页面架构设计
前言:以下内容基于React全家桶+AntD实战课程的学习实践过程记录.最终成果github地址:https://github.com/66Web/react-antd-manager,欢迎star. ...
- react后台管理系统路由方案及react-router原理解析
最近做了一个后台管理系统主体框架是基于React进行开发的,因此系统的路由管理,选用了react-router(4.3.1)插件进行路由页面的管理配置. 实现原理剖析 1.hash的方式 ...
- AntDesign(React)学习-4 登录页面提交数据简单实现
github代码:https://github.com/zhaogaojian/jgdemo 全国肺炎,过节期间没地方去在家学习antd. 一.感觉antd pro项目太庞大了,可以学习下结构和代码风 ...
- 【共享单车】—— React后台管理系统开发手记:AntD Form基础组件
前言:以下内容基于React全家桶+AntD实战课程的学习实践过程记录.最终成果github地址:https://github.com/66Web/react-antd-manager,欢迎star. ...
- React后台管理系统-用户列表页面
1.页面的结构 //遍历list, 返回数据 let listBody= this.state.list.map((user,index)=> { return ...
随机推荐
- 转载 常用Jquery插件整理大全
常用Jquery插件整理大全 做项目的时候总是少不了要用到Jquery插件,但是Jquery插件有太多,每次都要花费一些时间,因此本人就抽时间整理了一些Jquery插件,每个插件都有Demo或者是使用 ...
- js index of()用法
含义: indexOf() 方法可返回某个指定的字符串值在字符串中首次出现的位置.(工作中常用) 提示和注释: 注释:indexOf() 方法对大小写敏感! 注释:如果要检索的字符串值没有出现,则该方 ...
- Java NIO基本使用介绍
NIO主要包括Channel,Buffer,Selector三个核心元素组成. Channel即通道,l和Buffer有好几种类型.下面是JAVA NIO中的一些主要Channel的实现: FileC ...
- SpringBoot | 第二十六章:邮件发送
前言 讲解了日志相关的知识点后.今天来点相对简单的,一般上,我们在开发一些注册功能.发送验证码或者订单服务时,都会通过短信或者邮件的方式通知消费者,注册或者订单的相关信息.而且基本上邮件的内容都是模版 ...
- json解析数组类型的数据
//微信里一个检测是否有发送模版消息的权限的方法//此处的openid代表的微信用户openid,templateId代表的是模版消息idpublic boolean checkIsSendTempM ...
- jstack的使用方法
背景 记得前段时间,同事说他们测试环境的服务器cpu使用率一直处于100%,本地又没有什么接口调用,为什么会这样?cpu使用率居高不下,自然是有某些线程一直占用着cpu资源,那又如何查看占用cpu较高 ...
- servlet传值到servlet传值问题
今天在项目中遇到一个问题:中期项目自己做的新闻部分NewsPagerSortservlet传值时,正确答案如下 if(title!=""){ resp.sendRedirect(& ...
- 2 cmd中startup显示运行不了显示“不是内部或外部命令”
解决方案: 1 在C:\Windows\System32中检查cmd.exe是否存在(如果存在的话)(检查cmd.exe是否被误删) 2 在我的电脑——属性——环境变量——在系统变量找到Path编辑前 ...
- AngularJS(九):路由
本文也同步发表在我的公众号“我的天空” AngularJS路由 AngularJS路由可以让我们通过不同的URL访问不同页面(似乎是废话),其价值主要体现在单页面的web应用中(single page ...
- spring ehcache 使用详解
Spring 整合 Ehcache 管理缓存详解 yellowbutterfly 前言 Ehcache 是一个成熟的缓存框架,你可以直接使用它来管理你的缓存. Spring 提供了对缓存功能的抽象: ...