js验证form表单示例

检测测试了js表单验证,无jQuery(简单的功能有时无需jQuery版本)

js代码如下:

 

<script type="text/javascript">

function S(ba, hZ) {

try {

return (hZ && (hZ.document || hZ) || document).getElementById(ba);

}

catch (cg) {

return null;

}

}

var show = function(id, isVisible) {

var s1 = isVisible ? "" : "none";

S(id).style.display = s1;

}

var checkAlias = function() {

var _oForm = S("form1"), _oReg = /^[0-9a-zA-Z\.\-_]{4,32}$/, _oRegErr = /(^[\.\-_])|([\.\-_]$)/, _oRegErr2 = /[\.\-_][\.\-_]/, _bInvalid = false, _sMsg = "";

_oForm.alias.value = _oForm.alias.value.trim();

if (_oForm.alias.value == "") {

_bInvalid = true;

_sMsg = "请填写管理员帐号";

}

else if (_oForm.alias.value.length < 4 || _oForm.alias.value.length > 32) {

_bInvalid = true;

_sMsg = "帐号长度不对";

}

else if (!_oReg.test(_oForm.alias.value)) {

_bInvalid = true;

_sMsg = "帐号格式错误";

}

else if (_oRegErr.test(_oForm.alias.value)) {

_bInvalid = true;

_sMsg = "点、减号或下划线不能放在开头或结尾";

}

else if (_oRegErr2.test(_oForm.alias.value)) {

_bInvalid = true;

_sMsg = "点、减号或下划线不能连续出现";

}

if (_bInvalid) {

S("msg_alias_reason").innerHTML = _sMsg;

show("msg_alias_err", true);

show("msg_alias_ok", false);

return false;

}

else {

show("msg_alias_err", false);

show("msg_alias_ok", true);

}

return true;

};

var checkEmail = function() {

var _oForm = S("form1"), _oRegErr = /(^[\.\-_])|([\.\-_]$)/, _oRegEmail = /^(\w)+(\.\w+)*@(\w)+((\.\w+)+)$/, _bInvalid = false, _sMsg = "";

_oForm.email.value = _oForm.email.value.trim();

if (_oForm.email.value == "") {

_bInvalid = true;

_sMsg = "邮箱地址不能为空";

}

else if (_oRegErr.test(_oForm.email.value)) {

_bInvalid = true;

_sMsg = "点、减号或下划线不能放在开头或结尾";

}

else if (_oForm.email.value.length < 10 || _oForm.email.value.length > 32) {

_bInvalid = true;

_sMsg = "请输入正确的邮箱地址";

}

else if (!_oRegEmail.test(_oForm.email.value)) {

_bInvalid = true;

_sMsg = "邮箱格式错误,请重试";

}

if (_bInvalid) {

S("msg_email_reason").innerHTML = _sMsg;

show("msg_email_err", true);

show("msg_email_ok", false);

return false;

}

else {

show("msg_email_err", false);

show("msg_email_ok", true);

}

return true;

};

var checkFormInput = function() {

if (checkAlias() && checkEmail())

return true;

return false;

};

</script>

HTML代码如下:

<form id="form1" method="get" name="form1" onsubmit="return checkFormInput();">

<input type="hidden" name="action" value="signin" />

<div name="Content" class="mainPanel wd txt_left" style="margin-top:20px;">

<div class="regPanel">

<div class="b_size" style="padding:35px;">

<div class="">

<h2 class="bd" style="border-width:0 0 1px 0">用户注册 &nbsp;<span class="notice">(用来管理您企业邮的帐号)</span></h2>

<div class="formPanel" style="padding:20px 0 10px;">

<div class="tr">

<label class="colum" title="管理员帐号用来登录企业邮箱管理面板">用户名:</label>

<input type="text" class="txt b_size" value="" name="alias" onfocus="" onblur="checkAlias();" maxlength="32">

<span id="msg_alias_err" style="padding:0 5px; display:none;"><img align="absmiddle" class="icon_disable_m img_pad" src="dot.gif"><span id="msg_alias_reason" class="txt_red f_size">请填写管理员帐号</span></span>

<span id="msg_alias_ok" style="display: none; "><img align="absmiddle" class="icon_finish_m" src="dot.gif"></span>

</div>

<div class="addrtitle tr f_size tipsInfo">帐号由字母、数字组成,点(.)减号(-)下划线(_)不能放在开头或结尾,也不能连续出现</div>

<div class="tr">

<label class="colum" title="管理员帐号用来登录企业邮箱管理面板">邮箱地址:</label>

<input type="text" class="txt b_size" value="" name="email" onfocus="" onblur="checkEmail();" maxlength="32">

<span id="msg_email_err" style="padding:0 5px; display:none;"><img align="absmiddle" class="icon_disable_m img_pad" src="dot.gif"><span id="msg_email_reason" class="txt_red f_size">请填写管理员帐号</span></span>

<span id="msg_email_ok" style="display: none; "><img align="absmiddle" class="icon_finish_m" src="dot.gif"></span>

</div>

<div class="addrtitle tr f_size tipsInfo">请输入邮箱地址</div>

</div>

</div>

<div class="submitColumn" style="padding-left:105px;"><input type="submit" class="btnSubmit b_size" value="确定">&nbsp;&nbsp;<a href="/">取消</a></div>

</div>

</div>

</div>

</form>

js验证form表单示例的更多相关文章

  1. 第十七篇 JS验证form表单

    JS验证form表单   这节课做一个实际的,项目里会遇到的东西,例如登录页面,我们输入‘用户名’和‘密码’或者‘手机号’还有‘验证码’等等,它都会做一个前端验证,比如验证码,是6位有效数字组成,那么 ...

  2. js模拟form表单提交数据, js模拟a标签点击跳转,避开使用window.open引起来的浏览器阻止问题

    js模拟form表单提交数据, js模拟a标签点击跳转,避开使用window.open引起来的浏览器阻止问题 js模拟form表单提交数据源码: /** * js模拟form表单提交 * @param ...

  3. js重置form表单

      CreateTime--2017年7月19日10:37:11Author:Marydon js重置form表单 需要使用的方法:reset() 示例: HTML部分 <form id=&qu ...

  4. JS 提交form表单

    源码实例一:javascript 页面加裁时自动提交表单Form表单:<form method="post" id="myform" action=&qu ...

  5. js阻止form表单重复提交

    防止表单重复提交的方法总体来说有两种,一种是在js中阻止重复提交:另一种是在后台利用token令牌实现,大致思路是生成一个随机码放到session和form表单的隐藏输入框中,提交表单时两者对比,表单 ...

  6. 使用js提交form表单的两种方法

    提交form表单的时候瑶族一些简单的验证,验证完后才能提交,避免无效提交. 1.当输入用户名和密码为空的时候,需要判断.这时候就用到了校验用户名和密码,这个需要在前端页面写:有两种方法,一种是用sub ...

  7. jQuery.Validate.js验证大表单的优化

    最近在项目中有遇到一个Form表单中有200多个标签.在提交表单时网页会出现等待时间很长,甚至会出现网页奔溃的情况. 主要的原因是因为在使用jQuery.Validate.js进行Form验证的时候会 ...

  8. Js 提交 form 表单

    本文主要讲如何使用Js提交表单,在使用ajax进行异步验证的多数情况下,需要使用Js提交表单,以下简单说几种提交表单的方式: 1.document.getElementById("formI ...

  9. 参数传递的四种形式----- URL,超链接,js,form表单

    什么时候用GET,  查,删, 什么时候用POST,增,改  (特列:登陆用Post,因为不能让用户名和密码显示在URL上) 4种get传参方式 <html xmlns="http:/ ...

随机推荐

  1. 跟初学者学习IbatisNet第二篇

    在上一篇里面我们知道了什么是IbatisNet,并且知道了如何用IbatisNet进行简单的增删改查的操作,在这一篇文章里面我们主要介绍一下IbatisNet操作存储过程. 我们一般把存储过程分为两种 ...

  2. 查看linux ubuntu版本

    ubuntu版本: lsb_release -a  linux版本: uname -a proc目录下记录的当前系统运行的各种数据,version记录的版本信息直接可以通过cat查看到. 使用命令:c ...

  3. 一个爬取lativ诚衣网站上模特穿搭图片的爬虫

    show the code: [peter@localhost savvy]$ vi lativ.py # -*- coding:utf-8 -*- import requests,lxml,os f ...

  4. python024 Python3 实例

    Python3 实例 以下实例在 Python3.4.3 版本下测试通过: Python Hello World 实例 Python 数字求和 Python 平方根 Python 二次方程 Pytho ...

  5. 80. Hibernate 5.0命名策略使用naming-strategy 不起作用【从零开始学Spring Boot】

    [原创文章,转载请注明出处] 事情的起因:一不小心从1.3.3升级到了1.4.0版本,结果就碰到了各种悲催的事情了,好吧,Hibernate5.0的新特性就是其中一个坑,我们会发现我们配置的namin ...

  6. JIRA 6.3.6安装

    一:下载JIRA 从官网下载:https://www.atlassian.com/software/jira/download 我下载的版本是Linux版的 JIRA 6.3.6 wget http: ...

  7. Flex4分模块下样式动态加载步骤及相关问题的解决

    1.  给应用程序编写CSS文件 (1)在项目下创建CSS文件(任意路径,可以多个).本例在src下创建了5个样式文件 (2)Flex支持的CSS文件定义如下: a)  type selector(类 ...

  8. Segments--poj3304(判断直线与线段之间的关系)

    http://poj.org/problem?id=3304 给你几条线段  然后 让你找到一条直线让他在这条直线上的映射有一个重合点 如果有这条直线的话  这个重合的部分的两个端点一定是某两条线段的 ...

  9. noip 2015 day1

    T1 神奇的幻方 题目描述 幻方是一种很神奇的N*N矩阵:它由数字1,2,3,……,N*N构成,且每行.每列及两条对角线上的数字之和都相同. 当N为奇数时,我们可以通过以下方法构建一个幻方: 首先将1 ...

  10. http_load分析(转)

    http://www.cnblogs.com/xuning/p/3954057.html 一.前言 http_load是一款测试web服务器性能的开源工具,从下面的网址可以下载到最新版本的http_l ...