今天给大家带来个福利,我也是刚刚学习的很实用的一个东西,通过原生js模仿ajax的异步交互。

我的博客只是给那些新手看的大神勿喷,写的不好可留言,请指出。

因为当初自己学的时候一个问题不会找人问,知道初学者都不容易,所以我在我的博客中分享自己的学习经验,以及一些好玩的东西!!

废话不多说开始吧:

还是从最初讲:表单:html+css+js

先是HTML:

表单

表单HTML代码:

<form id="reg" title="注册">
  <div class="user">
    <span>姓名:</span>
      <input type="text" name="user" placeholder="请输入用户名" onblur="judge(this)">
     <span></span>
  </div>
<div class="mima">
  <span>密码:</span>
    <input type="text" name="pass" placeholder="请输入密码" onblur="judge(this)">
  <span></span>
</div>
<div class="chongfu">
<span>重复密码:</span>  
  <input type="text" name="passag" placeholder="重复输入密码" onblur="judge(this)">
<span></span>
</div>
<div class="zc">
<input class="sub" type="submit" value="立即注册">
</div>
</form> JS代码:
//创建加载完成验证表单
window.onload = function (){
//获取input name名为user的元素
var user = document.querySelector("input[name=user]");
  //获取input name名为pass的元素
var pass = document.querySelector("input[name=pass]");
//获取input name名为passag
var passag = document.querySelector("input[name=passag]");
/*用户名所在的input发生改变执行函数*/
user.onblur = function(){
//判断表单中name为user的元素的value值是否为空
if(user.value == ""){
     //如果为空在当前元素的兄弟集span里面写入内容文字为账号不能为空
this.parentNode.querySelector("input+span").innerText="账号不能为空";
}else{
      //如果不为空则不在兄弟集span里面写入文字
this.parentNode.querySelector("input+span").innerText="";
}
}
/*密码*/
pass.onblur = function() {
//判断表单中name为pass的元素的value值是否为空
if(pass.value == ""){
this.parentNode.querySelector("input+span").innerText="密码不能为空";
}else{
/*创建密码正则表达式*/
var pae = /^(?=.*[a-zA-Z])(?=.*[0-9])[a-zA-Z0-9]{8,12}$/;
/*用正则表达式匹配密码*/
paep = pae.test(pass.value);
/*判断匹配的结果*/
if(!paep){
        //不为真则在兄弟集写入文字内容密码格式不正确,然后input清空输入的内容
this.parentNode.querySelector("input+span").innerText="密码格式不正确";
pass.value="";
} else{
this.parentNode.querySelector("input+span").innerText="";
}
}
}
/*重复密码*/
passag.onblur = function() {
//判断表单中name为passag的元素的value值是否为空
if(passag.value == ""){
this.parentNode.querySelector("input+span").innerText="重复密码不能为空";
}else{
console.log(pass.value);
if(passag.value !== pass.value) {
this.parentNode.querySelector("input+span").innerText="密码不一致,请重新输入";
passag.value="";
} else {
this.parentNode.querySelector("input+span").innerText="";
}
}
} 其他的邮箱,验证都是同样的道理 CSS样式:这个就不多做讲解了,根据自己需求写自己的css样式

表单验证--通过原生js模仿ajax的异步交互的更多相关文章

  1. 表单验证的validate.js插件---jQuery Validation Plugin

    早上在公交车上看了一个关于慕课网的教程<表单验证的validate.js插件---jQuery Validation Plugin>,正好可以用到自己近期开发简易微博的注册页面和登录页面, ...

  2. JavaScript | 基础表单验证(纯Js)

    ———————————————————————————————————————————— 基础表单验证(纯js) - - - - - - - - - - - - - - - - - - - - - - ...

  3. ajax和servlet交互,表单日历插件,表单验证,form.js

    我的index.jsp <body> <a>点我获取数据</a> <table border=1px> <tr> <td>ID& ...

  4. 表单验证之validform.js使用方法

    一.validform有什么用? 网页上有大量的input需要你进行验证的时候,如果是弹窗的话,需要不停地判断,如果为空,弹窗.如果不是数字,弹窗. 所以要将这么多验证交给一个js去验证. 二.我现在 ...

  5. jQuery 表单验证 jquery.validator.js

    前端开发中经常会碰到表单的制作,其中必备的功能就是提交前的一些简单的验证,非空啊.手机号码啊.E-mail等等等等,这里是一个 jQuery 的表单验证插件,蛮好用的,收录一下. 下面是验证的效果图: ...

  6. 表单验证插件-validator.js 使用教程

    做网站的时候,常常会涉及到各种表单验证.选择一款好用的表单验证插件,会降低表单验证开发的难度.在开发中,我目前使用的表单验证插件是:validator.js. validator.js 是一款轻量的表 ...

  7. jquery.validate.js表单验证 jquery.validate.js的用法

    jquery.validate.js这个插件已经用了2年多了,是一个不可多得的表单验证最方便快捷的插件.基于jquery的小插件,基本小白一学就会上手,对于项目表单页面比较多,元素比较多的校验,该插件 ...

  8. 表单验证常用的JS正则表达式

    在表单验证中,使用正则表达式来验证正确与否是一个很频繁的操作,本文收集整理了15个常用的javaScript正则表达式,其中包括用户名.密码强度.整数.数字.电子邮件地址(Email).手机号码.身份 ...

  9. aspx中的表单验证 jquery.validate.js 的使用 以及 jquery.validate相关扩展验证(Jquery表单提交验证插件)

    这一期我们先讲在aspx中使用 jquery.validate插件进行表单的验证, 关于MVC中使用 validate我们在下一期中再讲     上面是效果,下面来说使用步骤 jQuery.Valid ...

随机推荐

  1. base库插件---拖动

    /** * Created by Administrator on 2014/6/5 0005. Base-drag 基于Base库的拖拽插件 tags为你要拖拽的元素参数, 数组形式传入 */ $( ...

  2. IWorkSpace接口介绍 1.打开各种数据库

    IWorkspace接口提供访问工作空间的通用属性和方法,如它的连接属性,以及包含的数据集的方法. IWorkspace的成员字段: Members   Description ConnectionP ...

  3. Docker 新网络 overlay 网络

    Overlay网络是指在不改变现有网络基础设施的前提下,通过某种约定通信协议,把二层报文封装在IP报文之上的新的数据格式. 这样不但能够充分利用成熟的IP路由协议进程数据分发,而且在Overlay技术 ...

  4. Python正则表达式,统计分析nginx访问日志

    目标: 1.正则表达式 2.oop编程,统计nginx访问日志中不同IP地址出现的次数并排序 1.正则表达式 #!/usr/bin/env python # -*- coding: utf-8 -*- ...

  5. stm32-ucos移植lwip-1(raw)

    之前在裸机环境下移植了lwip,功能还是很强大的,但是就我看来,这和uip其实差别也不大,其实lwip更强大的功能需要在操作系统之下才能发挥出来,今天就来做这个 首先我们需要移植操作系统,系统选择uc ...

  6. 三、MapReduce学习

    MapReducer是一种编程模型,用于大规模数据集(大于1TB)的并行运算.概念"Map(映射)"和"Reduce(化简)"                  ...

  7. spring 自动化构建项目

    STS 3.7.0.RELEASE http://spring.io/tools/sts/legacy

  8. LPC1768的iic通讯

    LPC1768有三路IIC,其中IIC0支持高速模式和plus模式,另外两路是普通IIC,使用IIC的过程如下 首先依然是打开IIC时钟,同时打开GPIO时钟 然后配置引脚为IIC功能 另外,因为ii ...

  9. NLPIR中文分词器的使用

    一.普通java项目 (1)添加项目jar包 File -> Project Structure     Libarries 添加jar包jna-4.0.0.jar (2)将Data文件夹复制到 ...

  10. stm32实现待机唤醒

    STM32的低功耗模式有3种:1.睡眠模式(CM3内核停止,外设仍然运行)2.停机模式(所有时钟都停止)3.待机模式(1.8v内核电源关闭) 进入待机模式的方法,以及设置WK_UP引脚用于把STM32 ...