一些常用的HTML5模式(pattern) 总结


Posted in HTML / CSS onJuly 14, 2015

最近在做手机页面时,遇到数字输入的键盘的问题,之前的做法只是一刀切的使用 type="tel",不过一直觉得九宫格的电话号码键盘上的英文字母太碍事了。于是想要尝试其它的实现方案,最终的结论却令人沮丧。不过也趁机详细了解了下pattern这个属性。
type="tel" 和 type="number" 的区别

这里还是先那么先交代一下最初遇到的问题。其实无论是tel还是number都不是完美的:
type="tel"

    优点是iOS和Android的键盘表现都差不多
    缺点是那些字母好多余,虽然我没有强迫症但还是感觉怪怪的啊。
一些常用的HTML5模式(pattern) 总结

type="number"

    优点是Android下实现的一个真正的数字键盘
    缺点一:iOS下不是九宫格键盘,输入不方便
    缺点二:旧版Android(包括微信所用的X5内核)在输入框后面会有超级鸡肋的小尾巴,好在Android 4.4.4以后给去掉了。
一些常用的HTML5模式(pattern) 总结

一些常用的HTML5模式(pattern) 总结

不过对于缺点二,我们可以用webkit私有的伪元素给fix掉:

XML/HTML Code复制内容到剪贴板
  1. input[type=number]::-webkit-inner-spin-button,     
  2.     input[type=number]::-webkit-outer-spin-button {    
  3.         -webkit-appearance: none;    
  4.         appearance: none;    
  5.         margin: 0;    
  6.     }  

pattern属性

pattern用于验证表单输入的内容,通常HTML5的type属性,比如email、tel、number、data类、url等,已经自带了简单的数据格式验证功能了,加上pattern后,前端部分的验证更加简单高效了。

显而易见,pattern的属性值要用正则表达式。
实例
简单的数字验证

数字的验证有两个:

XML/HTML Code复制内容到剪贴板
  1. <input type="number" pattern="\d">     
  2. <input type="number" pattern="[0-9]*">    

一些常用的HTML5模式(pattern) 总结

对表单验证来说,这两个正则的作用是一样的,表现的话差异就很大:

    iOS中,只有[0-9]\*才可以调起九宫格数字键盘,\d 无效
    Android 4.4以下(包括X5内核),两者都调起数字键盘;
    Android 4.4.4以上,只认 type 属性,也就是说,如果上面的代码将 type="number" 改为 type="text" ,将调起全键盘而不会是九宫格数字键盘。

常用的正则表达式

pattern的用法都一样,这里不再??赂髦窒晗感捶?耍?皇橇谐隼匆恍┏S玫恼?蚓秃昧耍?/p>

    信用卡 [0-9]{13,16}
    银联卡 ^62[0-5]\d{13,16}$
    Visa: ^4[0-9]{12}(?:[0-9]{3})?$
    万事达:^5[1-5][0-9]{14}$
    QQ号码: [1-9][0-9]{4,14}
    手机号码:^(13[0-9]|14[5|7]|15[0|1|2|3|5|6|7|8|9]|18[0|1|2|3|5|6|7|8|9])\d{8}$
    身份证:^([0-9]){7,18}(x|X)?$
    密码:^[a-zA-Z]\w{5,17}$ 字母开头,长度在6~18之间,只能包含字母、数字和下划线
    强密码:^(?=.*\d)(?=.*[a-z])(?=.*[A-Z]).{8,10}$ 包含大小写字母和数字的组合,不能使用特殊字符,长度在8-10之间
    7个汉字或14个字符:^[\u4e00-\u9fa5]{1,7}$|^[\dA-Za-z_]{1,14}$

浏览器支持

很不幸,pattern的浏览器支持很惨:
一些常用的HTML5模式(pattern) 总结

但是如果只是如文章开头提到的改数字键盘的话,iOS和Android都是没有问题的。

HTML / CSS 相关文章推荐
利用css3实现的简单的鼠标悬停按钮
Nov 04 HTML / CSS
CSS3属性background-size使用指南
Dec 09 HTML / CSS
使用CSS3编写灰阶滤镜来制作黑白照片效果的方法
May 09 HTML / CSS
浅析css3中matrix函数的使用
Jun 06 HTML / CSS
CSS3中的常用选择器使用示例整理
Jun 13 HTML / CSS
一篇文章带你学习CSS3图片边框
Nov 04 HTML / CSS
用HTML5 Canvas API中的clearRect()方法实现橡皮擦功能
Mar 15 HTML / CSS
html5调用摄像头功能的实现代码
May 07 HTML / CSS
html5实现完美兼容各大浏览器的播放器
Dec 26 HTML / CSS
使用分层画布来优化HTML5渲染的教程
May 08 HTML / CSS
HTML5中input输入框默认提示文字向左向右移动的示例代码
Sep 10 HTML / CSS
HTML静态页面获取url参数和UserAgent的实现
Aug 05 HTML / CSS
针对HTML5的Web Worker使用攻略
Jul 12 #HTML / CSS
极简的HTML5模版
Jul 09 #HTML / CSS
深入探究HTML5的History API
Jul 09 #HTML / CSS
HTML5中Localstorage的使用教程
Jul 09 #HTML / CSS
HTML5到底会有什么发展?HTML5的前景展望
Jul 07 #HTML / CSS
HTML5新增的8类INPUT输入类型介绍
Jul 06 #HTML / CSS
用HTML5实现鼠标滚轮事件放大缩小图片的功能
Jun 25 #HTML / CSS
You might like
做个自己站内搜索引擎
2006/10/09 PHP
PHP之变量、常量学习笔记
2008/03/27 PHP
PHP使用glob函数遍历目录或文件夹的方法
2014/12/16 PHP
Centos 6.5系统下编译安装PHP 7.0.13的方法
2016/12/19 PHP
PHP如何通过表单直接提交大文件详解
2019/01/08 PHP
javascript中使用replaceAll()函数实现字符替换的方法
2010/12/25 Javascript
Javascript 面试题随笔
2011/03/31 Javascript
需要牢记的JavaScript基础知识
2016/09/25 Javascript
jQuery实现的简单在线计算器功能
2017/05/11 jQuery
浅谈Vue2.0中v-for迭代语法的变化(key、index)
2018/03/06 Javascript
nodejs实现解析xml字符串为对象的方法示例
2018/03/14 NodeJs
Vue列表渲染的示例代码
2018/11/01 Javascript
简单实现节流函数和防抖函数过程解析
2019/10/08 Javascript
在node环境下parse Smarty模板的使用示例代码
2019/11/15 Javascript
Element-ui树形控件el-tree自定义增删改和局部刷新及懒加载操作
2020/08/31 Javascript
JavaScript 实现轮播图特效的示例
2020/11/05 Javascript
[01:36:19]Secret vs NB 2018国际邀请赛小组赛BO2 第一场 8.19
2018/08/21 DOTA
Python文件操作类操作实例详解
2014/07/11 Python
python脚本实现查找webshell的方法
2014/07/31 Python
Python脚本文件打包成可执行文件的方法
2015/06/02 Python
基于python中staticmethod和classmethod的区别(详解)
2017/10/24 Python
Python使用MyQR制作专属动态彩色二维码功能
2019/06/04 Python
Django REST framework 视图和路由详解
2019/07/19 Python
Python调用.net动态库实现过程解析
2020/06/05 Python
python实现磁盘日志清理的示例
2020/11/05 Python
MAC彩妆英国官网:M·A·C UK
2018/05/30 全球购物
自荐信格式范文
2013/10/07 职场文书
医疗纠纷协议书
2014/04/16 职场文书
工程售后服务承诺书
2014/05/21 职场文书
大型演出策划方案
2014/05/28 职场文书
公司演讲稿开场白
2014/08/25 职场文书
2015年女生节活动总结
2015/02/27 职场文书
2015年成本会计工作总结
2015/10/14 职场文书
《穷人》教学反思
2016/02/19 职场文书
为什么MySQL选择Repeatable Read作为默认隔离级别
2021/07/26 MySQL
Win11运行育碧游戏总是崩溃怎么办 win11玩育碧游戏出现性能崩溃的解决办法
2022/04/06 数码科技