- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我想在这里做的是要求将电话号码作为 (XXX) XXX-XXXX 输入到我的 HTML 表单中,并将 SS 号码输入为 XXX-XX-XXXX。就是这样。
我这样做的唯一原因是表单提交结果一致且易于导出到 Excel。
我被告知要使用 Javascript 来执行此操作,但也许我还不够先进,无法理解执行此操作的所有步骤。
请记住我是初学者,有人可以在这里为我指明正确的方向吗?
哇,非常感谢 Ethan 和@suman-bogati!我快到了!该字段现在会弹出一条错误消息,指出要使用正确的格式 555-55-5555。那太棒了。但无论我在该字段中输入什么,弹出窗口都会持续存在。我试过 555-55-5555 和 555555555 都没有被接受。这是该字段的 HTML:
<label>
Social Security Number:
<input id="ssn" required pattern="^d{3}-d{2}-d{4}$"
title="Expected pattern is ###-##-####" />
</label>
</div>
<script>$('form').on('submit', function(){
$(this).find('input[name="SocialSecurity"]').each(function(){
$(this).val() = $(this).val().replace(/-/g, '');
});
$(this).find('input[name="ssn"]').each(function(){
$(this).val() = $(this).val().replace(/-/g, '');
});
});</script>
<br />
最佳答案
最简单的方法是简单地使用多个字段:
<div>
Phone:
(<input type="text" name="phone-1" maxlength="3">)
<input type="text" name="phone-2" maxlength="3">-
<input type="text" name="phone-3" maxlength="4">
</div>
<div>
SSN:
<input type="text" name="ssn-1">-
<input type="text" name="ssn-2">-
<input type="text" name="ssn-3">
</div>
虽然这种方法确实很简单,但并不好。用户必须按 Tab 键或单击每个字段才能输入数据,没有什么(除了常识)可以阻止他们输入数字以外的内容。
我总觉得,在验证方面,越少妨碍用户越好。让他们以他们喜欢的任何格式输入他们的电话号码,然后删除它,删除除数字以外的所有内容。这样用户可以输入“5555551212”或“(555) 555-1212”,但数据库将始终保存“5555551212”。
另一件需要考虑的事情是 HTML5 为电话号码(但不是 SSN)提供了一些很好的特定类型。现代浏览器将负责所有输入验证,更好的是,移动设备将显示数字键盘而不是整个键盘。
鉴于此,显示表单的最佳方式是:
<div>
<label for="fieldPhone">Phone: </label>
<input type="tel" id="fieldPhone" placeholder="(555) 555-1212">
</div>
<div>
<label for="fieldSsn">SSN: </label>
<input type="text" id="fieldSsn" name="ssn" placeholder="555-55-5555" pattern="\d{3}-?\d{2}-?\d{4}">
</div>
如果用户使用现代浏览器,这将为您处理用户端的输入验证。如果他们不这样做,您将不得不使用验证库或 polyfill。这里有完整的 HTMl5 表单验证 polyfill 列表:
https://github.com/Modernizr/Modernizr/wiki/HTML5-Cross-Browser-Polyfills#wiki-web-forms
所以现在剩下的就是在将数据保存到数据库时对其进行规范化。
做这件事的理想地点是后端;不过,它并没有说明您的表单要去哪里,所以您可能对后端的处理方式没有任何发言权。因此,您可以改为在前端执行此操作。例如,使用 jQuery:
$('form').on('submit', function(){
$(this).find('input[type="tel"]').each(function(){
$(this).val() = $(this).val().replace(/[\s().+-]/g, '');
});
$(this).find('input[name="ssn"]').each(function(){
$(this).val() = $(this).val().replace(/-/g, '');
});
});
这也不是一个完美的方法:如果您在此函数中进行验证,并且验证失败,用户将看到他或她的输入被规范化版本替换,这可能会令人不安。
最好的方法是使用 AJAX 和 .serialize
;您不仅可以更好地控制 UI,还可以进行所有您想要的验证。但这可能有点超出您现在需要做的事情。
请注意,电话验证是最棘手的。 HTML5 电话验证非常宽松,允许人们输入格式非常复杂的国际电话号码。甚至美国的人有时也会输入“+1 (555) 555-1212”这样的电话号码,然后您有 8 位数字而不是 7 位数字。如果您真的想将它们限制为 7 位数字,则必须添加您的自己的自定义验证:
/^\(?\d{3}\)?[.\s-]?\d{3}[.\s-]\d{4}$/
这将涵盖人们使用的所有常见变体(句点、空格、破折号、括号),并且仍然只允许使用 7 位数的美国电话号码。
这是一个演示 HTML5 验证和规范化的 jsfiddle:
希望对您有所帮助!
关于javascript - HTML 表单字段 - 如何要求输入格式,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21650617/
我有一个类和构造函数,如下所示: def init(log, edge): if edge: return Helper(log, edge) return Booka
关闭。这个问题需要更多focused .它目前不接受答案。 想改善这个问题吗?更新问题,使其仅关注一个问题 editing this post . 4年前关闭。 Improve this questi
有人知道在 mongo 上安装标准 ubuntu 需要多少磁盘空间和内存吗?试图找出我的 VPS 需求... 最佳答案 没有最低要求,但我不建议在与您的网络服务器相同的机器上运行 Mongo。 Mon
我的 Django 项目有一个虚拟环境,但是当我 pip 击 pip freeze 时,我得到了一个必须是全局站 pip 包列表的东西,包括太多包,比如ubuntu包和这么多不相关的东西。无论 vir
我曾尝试在 Heroku 上部署我的应用程序,但 smth 出错了。 错误:找不到满足要求的版本 get==2019.4.13(来自 -r/tmp/build_53ad6d03_/requiremen
我无法将 semantic-ui-calendar npm 模块加载到我的应用程序中。 我已经使用脚本标签成功地将它加载到我的 HTML 中, 但每次我尝试将它加载到我的应用程序中时,我都会出错。 在
如何修复 php.ini 中“require”函数内的地址?它进行故障排除并显示错误: 警告:require (..) 无法打开流:没有这样的文件或目录。 文件“db_connection.php”工
我有一个在 Node.js 应用程序中使用的外部库 ( Objection.js )。我创建了一个基本模型类,它为我的实体模型扩展了 Objection 的 Model 类: const { Mode
有谁知道在哪里可以找到RHEL5的GLIBC2.7,如果没有这个,Android模拟器将无法启动。它会给出一条消息,要求GLIBC 2.7或更高版本。 我尝试在网上搜索,但没有找到 最佳答案 我也遇到
Android 设备是否有任何要求/指南?例如按钮数量或所需的最少按钮数量。 还有没有菜单和后退按钮的安卓设备吗? (我知道就可用性而言,没有菜单/后退按钮会杀死大多数应用程序,我只是想了解更多有关该
我想要求/包含一个文件并将其内容检索到一个变量中。 test.php index.php ".$test; ?> 类似于 file_get_contents() 但它仍应执行 PHP 代码。这可能吗
我想要求/包含一个文件并将其内容检索到一个变量中。 test.php index.php ".$test; ?> 类似于 file_get_contents() 但它仍应执行 PHP 代码。这可能吗
我正在尝试在我的 Linux Mint 发行版上安装一个 python 模块“pyAudioProcessing”(https://github.com/jsingh811/pyAudioProces
我已经创建了我的第一个 composer 包,它具有 MySQL 和 MongoDB 的功能,但是,它不需要两者。我意识到有人可能只想将这个包与两个数据库之一一起使用,目前我有: "require":
我想调试以下函数,但假设在调试器中查看 moreajaj 的参数等于什么(假设不像在这个人为的示例中那么明显)是有用的。我可以在调试器框架中打印它,但是在每个参数的每个框架中都这样做很烦人。在宣布每一
我有一些生成的 GNUmakefiles,我需要从中提取变量的值。 有没有一种简单的方法可以在不修改 makefile 的情况下查看变量的值? 仅供引用,变量包含 emacs c-macro-expa
我正在使用 aspell 在 Linux 上拼写检查 LaTeX 文档。我的文档经常包含各种编程语言的代码示例,我希望 aspell 在拼写检查时简单地跳过这些行。 我可以在文档中写些什么来关闭一段文
我有一个包含多个列的数据集... 一列是具有重复值的主石斑鱼列,另一列是具有 bool 值 (1,0) 的 NUMBER,如下所示: grp bool --- ---- A 1 A 1 A
出于测试目的,我正在尝试删除一些 amd 模块并从服务器重新加载更新版本 - 目的是不刷新浏览器。 我目前正在执行以下操作,但浏览器仍然没有从网络重新加载项目。 var scripts = docum
当我键入irb> require 'rubygems'时,它返回false。我的Rails应用程序中有很多 gem ,这些 gem 显然可以正常工作-耙子,activerecord等。这里可能出什么问
我是一名优秀的程序员,十分优秀!