这里我是写了一个简单的注册表单验证功能,亲测有效,一起来看看吧!

首先我的HTML代码是这样的:

class大家可以忽略一下,这里我项目使用的是bootstrap的样式。

输入用户名和密码用的是正则表达式控制格式,在title里有描述。

最后一行的h6标签用来存放提示信息。

 <form class="form-horizontal" v-on:submit="addUserNormal">
<div class="form-position">
<div class="form-group">
<span class="glyphicon glyphicon-user control-label col-sm-2"></span>
<div class="col-sm-6">
<input type="text" class="form-control" id="username"
placeholder="请输入用户名" pattern="^[a-zA-Z][a-zA-Z0-9_]{4,15}$" title="用户名格式为:字母开头,允许5-16字节,允许字母数字下划线" v-model="user.username">
</div>
</div>
<div class="form-group">
<span class="glyphicon glyphicon-question-sign control-label col-sm-2"></span>
<div class="col-sm-6">
<input type="password" class="form-control" id="password1"
placeholder="请输入密码" pattern="^[a-zA-Z][a-zA-Z0-9_]{4,15}$" title="密码请输入以字母开头,长度在5~17 之间,只能包含字符、数字和下划线组成的字符串" onpaste="javascript: return false;" v-model="user.password1">
</div>
</div>
<div class="form-group">
<span class="glyphicon glyphicon-question-sign control-label col-sm-2"></span>
<div class="col-sm-6">
<input type="password" class="form-control" id="password2"
placeholder="再次输入密码" pattern="^[a-zA-Z][a-zA-Z0-9_]{4,15}$" title="密码请输入以字母开头,长度在5~17 之间,只能包含字符、数字和下划线组成的字符串" onpaste="javascript: return false;" v-model="user.password2">
</div>
</div>
<div class="form-group middle">
<div class="col-sm-6">
<button type="submit" class="login-btn-position btn btn-block btn-success">新用户注册</button>
</div>
</div>
</div>
</form>
<h6 id="alert" class="alert"></h6>

这是我的函数,当点击提交时触发,由于获取json数据在network里明文显示了,那么这里我使用了md5加密,使用方法是加入js文件,括号里放字符串就能自动加密成密文,可以在注册后将输入的密码传回后台保存,登录时返回密文进行对比就行。这里要注意的是:md5加密是不可转回的,别人就算获取了你的密文也没办法破解你的密码,但是如果你的业务需求需要保存用户的密码可以使用其他加密方法。

解释补充在了注释里

 addUserNormal(e){
var password1 = md5(this.user.password1);
var password2 = md5(this.user.password2);
var No = md5();
var num = 0;
var alertHtml = document.getElementById("alert");
if(!this.user.username){
alertHtml.innerHTML="用户名为空,请正确填写!";
alertHtml.style.display="block";
}
else if(password1 === No || password2 === No){//若有一个密码为空,则出现提示信息
alertHtml.innerHTML="密码为空,请正确填写!";
alertHtml.style.display="block";
}
      else if(password1 != password2){//若密码不一致,则出现提示信息
alertHtml.innerHTML="密码不一致,请正确填写!";
alertHtml.style.display="block";
      }
else{
for(var i = 0; i < this.users.length; i++){//遍历获得的总用户名
if(this.user.username === this.users[i].username){
num++; //r若有注册过,则num会变动
}
}
if(num != 0){
alert("用户名"+this.user.username+"已注册!");
//这里希望有注册的用户名后刷新页面
return;
}
let userNormal = {
username:this.user.username,
password:password1,
}
$.post("http://localhost:3000/userNormal",userNormal).
then(function(response){
// console.log(response);//传回成功信息
alert("用户"+userNormal.username+"注册成功!");
window.location.href="LoginNormal.html";
})
}
e.preventDefault();//这里好像是阻止了登录时候的刷新,如果你输入错了,这里还是有用处
}

加油啊柯基~

JS简单表单验证的更多相关文章

  1. ★★★【卡法 常用js库】: js汇合 表单验证 cookie设置 日期格式 电话手机号码 email 整数 小数 金额 检查参数长度

    [卡法 常用js库]: js汇合 表单验证  cookie设置  日期格式  电话手机号码  email  整数  小数  金额   检查参数长度 // +---------------------- ...

  2. JS通用表单验证函数,基于javascript正则表达式

    表单的验证在实际的开发当中是件很烦琐又无趣的事情今天在做一个小项目的时候,需要JS验证,寻找到一个比较好的东西 地址如下: http://blog.csdn.net/goodfunman/archiv ...

  3. 原生js的表单验证

    最近在学原生的js,把一些练手的代码往博客放一放,权当积累经验,若有错漏,或是觉得浅显,大家不要见怪. 这是一个原生js编写的简单的表单验证: <!DOCTYPE html><htm ...

  4. 原生JS写表单验证提交功能

    先上效果图: 表单的基础内容就是昵称判断.手机号判断.邮箱判断.身份证号码判断,这里是用到正则验证检验格式. 页面的表单写法就是一个form的提交.输入框用input来实现,输入内容用value来获取 ...

  5. js基础-表单验证和提交

    基础知识: 原始提交如下: <form action="/login" method="post" id="form1"> &l ...

  6. 如何利用jQuery进行简单表单验证

    <!DOCTYPE html><html><head><meta charset="utf-8"><meta name=&qu ...

  7. 表单提交学习笔记(二)—使用jquery.validate.js进行表单验证

    一.官网下载地址:http://plugins.jquery.com/validate/ 二.用法 1.在页面上进行引用 <script src="~/scripts/jquery-1 ...

  8. js——form表单验证

    用js实现一个简易的表单验证 效果: 代码: <html> <head> <title>js校验form表单</title> <meta char ...

  9. 原生js制作表单验证,基本的表单验证方法

    表单验证是web前端最常见的功能之一,也属于前端开发的基本功.自己完成一个表单验证的开发,也有助于加深对字符串处理和正则表达式的理解. 基本的表单验证包括如:字母验证.数字验证.字母和数字验证.汉字验 ...

随机推荐

  1. python学习 day1 (3月1日)

    01 cpu 内存 硬盘 操作系统 CPU:中央处理器,相当于人大脑. 飞机 内存:临时存储数据. 8g,16g, 高铁 1,成本高. 2,断电即消失. 硬盘:长期存储大量的数据. 1T 512G等等 ...

  2. python中的函数嵌套

    一.函数嵌套 1.只要遇到了()就是函数的调用.如果没有就不是函数的调用 2.函数的执行顺序 遵循空间作用域,遇到调用才执行 def outer(): def inner(): print(" ...

  3. 使用Ant发布web应用到tomcat

    使用Ant发布web应用到tomcat 来自:http://blog.csdn.net/hbcui1984/article/details/1954537 今天在公司用ant写了个部署web应用的脚本 ...

  4. hibernate添加数据报错:Could not execute JDBC batch update

    报错如下图所示: 报错原因:在配置文件或注解里设置了字段关联,但数据却没有关联. 解决方法:我的错误是向一个多对多的关联表里插入数据,由于表中一个字段的数据是从另一张表里get到的,通过调试发现,从以 ...

  5. MongoDB-增删改

    MongoDB的shell使用了Js引擎,因此能运行任意的Js程序. MongoDB中常用基本数据类型: null:空值或者不存在的字段Boolean:true,false数值型:{"x&q ...

  6. 5.Vue临时上传文件夹

    1.在项目目录中,通过npm install multiparty进行安装必要组件npm install multiparty --save-dev 2.app.js中添加app.use(bodyPa ...

  7. 20170831工作日记--自定义View学习

    学习了LayoutInflater的原理分析.视图的绘制流程.视图的状态及重绘等知识,按类型来划分的话,自定义View的实现方式大概可以分为三种,自绘控件.组合控件.以及继承控件.那么下面我们就来依次 ...

  8. 【repost】Chrome 控制台console的用法

    下面我们来看看console里面具体提供了哪些方法可以供我们平时调试时使用. 目前控制台方法和属性有: ["$$", "$x", "dir" ...

  9. 20169207《Linux内核原理与分析》第十周作业

    这周除了阅读学习教材「Linux内核设计与实现 (Linux Kernel Development)」第教材第15,16章外.我们还需要接着完成学习MOOC「Linux内核分析」第八讲「Linux系统 ...

  10. (最短路 弗洛伊德) Til the Cows Come Home -- POJ --2387

      #include <iostream> #include <cstdlib> #include <cstring> #include <cstdio> ...