form表单验证

表单验证分类:

1、必填性:可以利用原生的表单元素的自身属性,required ;当采用表单原生的提交(非Ajax 异步请求(js方式提交))方式时,可以调起内部的校验,不合法会有弹窗提示:"请填写此字段"。这个是HTML5中新增的。


案例.png

点击submit按钮时候,表单内必填字段处会有提示。
2、长度限制:利用原生自带的maxlength="数字",minlength="数字"
3、规定的类型:写正则过滤,对应错误提示代码。
4、逻辑校验:自己写js代码。(第一个数值要小于后一个数值-时间段的选择等问题上)

原生表单的形式:

form(action method)>input[*]+input[submit]
每一个都是必要的,最外层必须由form 标签包裹,内部必须由类型是submit的输入框。

一些定制demo

1.修改必填性不合法时候的提示文字

核心代码:

oninvalid="setCustomValidity('请输入您的姓名');" oninput="setCustomValidity('');" 

完整代码:

 <input type="text" id="username" required oninvalid="setCustomValidity('请输入您的姓名');" oninput="setCustomValidity('');" >
demo.png
2.阻止form表单点击提交按钮时自动提交
$("input:submit").click(function(e){
     e = e||window.event;
    e.preventDefault();    //阻止默认行为
})

或是:
    form表单.onsubmit = function () {
        return false
    }

验证是否生效:
填写好合法的字段,点击提交,浏览器的刷新按钮不动(表单提交时同步行为,肯定会刷新页面),说明ok了,或是给action一个提交的后台地址,这里可以给百度的试试,点击提交,不跳转百度,说明ok。


刷新按钮.png
3.定制required字段不符时的提示框的样式。

对于这个H5的新功能,貌似只能修改文字。不同浏览器的渲染样式是不一样的(浏览器程序中定制了提示框的API)

)。

4.定制required字段不符时的输入框的样式。
html:
<input type="text" name="name" required>
css:
/* 无效 */
input:required:invalid{
    CSS代码
}
/* 有效 */
input:required:valid{
    CSS代码
}
5.占位符的样式定制
 input::placeholder {
            color: #DDDDDD;
            font-size: 16px;
            letter-spacing: 1px;
        }

        /*placeholder兼容处理*/
 input::-webkit-input-placeholder {
            color: #DDDDDD;
            font-size: 16px;
            letter-spacing: 1px;
        }
 input:-ms-input-placeholder {
            color: #DDDDDD;
            font-size: 16px;
            letter-spacing: 1px;
        }

其他

submit和button提交表单的区别
input 的type 类型分别为submit和button时候放在form标签里的区别:

  1. <input type="button" />单纯的一个按钮。没有默认行为,不写js脚本的话,按下去什么反应也没有。

  2. <input type="submit" /> 有默认行为,点击会提交 form,除非写了js阻止它。(<form onsubmit="return false;"> )

  3. <button> 标签,这个按钮放在 form 中也会点击自动提交,比前两个的优点是样式好定制些。缺点可能有浏览器兼容问题。

附一登录的源码:

可以到我的github上下载:
https://github.com/Macrolam/login

参考文章:

1:http://www.the-art-of-web.com/html/html5-form-validation/

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,922评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,591评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,546评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,467评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,553评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,580评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,588评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,334评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,780评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,092评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,270评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,925评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,573评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,194评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,437评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,154评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,127评论 2 352

推荐阅读更多精彩内容

  • HTML表单 在HTML中,表单是 ... 之间元素的集合,它们允许访问者输入文本、选择选项、操作对象等等,然后将...
    兰山小亭阅读 3,413评论 2 14
  • 版本:Angular 5.0.0-alpha 表单是商业应用的支柱,我们用它来执行登录、求助、下单、预订机票、安排...
    soojade阅读 1,275评论 0 1
  • form简介 是HTML中的一个元素,它表示文档中的一个区域,这个区域包含了交互控件,用于向web服务器提交信息。...
    七里之境阅读 1,325评论 0 1
  • 表单基础知识 在HTML中,表单是由 元素来表示的,而在JS中,表单对应的则是HTMLFormElement类型。...
    oWSQo阅读 907评论 0 1
  • <input>标签 标签用于搜集用户信息,根据不同的type属性值,输入字段拥有很多种形式。输入字段可以是文本字段...
    _空空阅读 4,020评论 0 3