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

首先我的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. OpenCV-图像通道转换问题

    OpenCV-MAT对象中使用plt.imshow(img[:,:,::-1])如何实现将第二轴反向? 系统平台:win10 x64 一.明确几个概念: 1.OpenCV内部每个通道并没有固定对应某种 ...

  2. (17)Questioning the universe

    https://www.ted.com/talks/stephen_hawking_asks_big_questions_about_the_universe/transcript00:13There ...

  3. 计算误差函数的积分--erf(x)

    注意exp(-x^2-y^2) 可以拆成exp(-x^2) * exp(-y^2) 对 dx积分时,另外一个可以当常数提出到积分号外,另外 -b到b的积分看做常数提取到积分号外

  4. SQL2008 2机镜像

    清除设置 //删除端点 declare @sql varchar() declare @mirrName varchar() select @mirrName=name from sys.databa ...

  5. Java获取文件后缀名

    int dot = filename.lastIndexOf('.'); if ((dot > -1) && (dot < (licenceImg.getOriginalF ...

  6. nginx 下载 大文件被截断

    如果出现大文件被截断,且ngix的日志大量出现以下类似报错: 则说明是nginx没有fastcgi_temp的读写权限.其中fastcgi_temp是自己的文件夹名称,每个人的不同且路径也会不同,这个 ...

  7. spring 事务的传播特性

    1.声明式事物中,一个类serviceA的方法test1()调用另一个类serviceB的方法test2() 要是serviceB的test2()事务配置在xml文件中为REQUIRED,又在此方法上 ...

  8. jQuery如何获取元素及选择器的参考

    获取元素 Jquery当中几乎所有的功能.选择.事件处理等都用到了这个函数.通常用来获取元素,获取到的元素都会被存储为jQuery对象. 例如: 先设定一个id为aaa的div <body> ...

  9. python生成器实例

    生成器是一种特殊的迭代器,它有yield语句 #coding:utf-8def fibs(max): n,a,b = 0,0,1 while n < max: yield b a , b = b ...

  10. Hive为什么要分桶

    对于每一个表(table)或者分区, Hive可以进一步组织成桶,也就是说桶是更为细粒度的数据范围划分.Hive也是针对某一列进行桶的组织.Hive采用对列值哈希,然后除以桶的个数求余的方式决定该条记 ...