首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 ><input>上模式“HTML5”属性的Javascript回退

<input>上模式“HTML5”属性的Javascript回退
EN

Stack Overflow用户
提问于 2011-11-28 11:19:38
回答 2查看 9.7K关注 0票数 7

我使用HTML5 "pattern“属性进行客户端验证(请不要告诉我服务器端验证,我已经知道了)。我想为使用没有“模式”支持的浏览器的用户使用Javascript或jQuery后备。有什么好方法可以做到这一点呢?

下面是一个输入元素的示例:

代码语言:javascript
运行
复制
<input type=tel name=contact[phone] id=phone required pattern=^(?:(?:\+?1\s*(?:[.-]\s*)?)?(?:\(\s*([2-9]1[02-9]|[2-9][02-8]1|[2-9][02-8][02-9])\s*\)|([2-9]1[02-9]|[2-9][02-8]1|[2-9][02-8][02-9]))\s*(?:[.-]\s*)?)?([2-9]1[02-9]|[2-9][02-9]1|[2-9][02-9]{2})\s*(?:[.-]\s*)?([0-9]{4})(?:\s*(?:#|x\.?|ext\.?|extension)\s*(\d+))?$>
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2011-11-28 11:24:25

在窗体的submit事件上(或任何地方),使用其现有的pattern属性对其进行验证。

代码语言:javascript
运行
复制
var input = document.getElementsByName('contact[phone]')[0],
    isValid = input.value.search(new RegExp(input.getAttribute('pattern'))) >= 0;

jsFiddle

您需要首先检查浏览器的兼容性,看看它是否支持pattern属性。你可以用Modernizr做到这一点。

票数 7
EN

Stack Overflow用户

发布于 2011-11-28 11:27:28

您可以使用Modernizr查看用户的浏览器所支持的内容。

Detecting HTML5 with Modernizr

Modernizer让你可以做这样的事情:

代码语言:javascript
运行
复制
if (Modernizr.canvas) {
  // let's draw some shapes!
} else {
  // no native canvas support available :(
}
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/8291152

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档