Javascript验证下拉菜单和文本输入
Javascript Validation Dropdown and Text Input
我已经找遍了,找不到一个很好的解决方案,或者如果有可能与客户端验证。
我的客户要求用户根据下拉菜单中的选择限制固定长度的数字组合。
例子:
下拉选择
公用一个
实用程序B
实用C
文本输入
如果用户选择公用事业A,他们必须提供一个8位的帐号。
如果用户选择工具B,他们必须提供一个10位的帐号。
如果用户选择工具C,他们必须提供一个12位的帐号。
谁知道一个简单的javascript解决方案,将提供答案?我都快把自己折磨死了。
谢谢!
给你!
HTML<select id="Select" onchange="checkText()">
<option value="8"> A</option>
<option value="10"> B</option>
<option value="12"> C</option>
</select>
<input id="Enter" type="text" onchange="checkText()" />
<div id="Message"></div>
JavaScript function checkText(input) {
if(document.getElementById("Enter").value.length != document.getElementById("Select").selectedOptions[0].value) {
document.getElementById("Message").innerHTML = "Your ID has to be " + document.getElementById("Select").selectedOptions[0].value + " digits long";
} else {
document.getElementById("Message").innerHTML = "";
}
}
这一点都不聪明。但我不会替你做事。你可以很容易地从这里接起。
我还创建了一个jsFiddle
其中select
是您的下拉列表,input
是您的输入字符串,您可以使用:
if ( !/^'d+$/.test(input) ||
input.length != [ 8, 10, 12 ][ select.selectedIndex ] ) {
// Input invalid
}
关于@Amberland的进一步反馈:
或者,对于更通用的解决方案,将所需的位数存储为每个选项元素的值,例如<option value=8>Utility A</option>
,并使用:
if ( !/^'d+$/.test(input) || input.length != select.value ) {
// Input invalid
}
相关文章:
- 让文本输入幻灯片显示输入时的新文本输入?然后向后滑动
- Sails.js:同时发布文本输入和一个文件
- 来自文本输入null的html javascript变量
- 当没有文本输入聚焦时检测空格键按下
- JS中的按钮和文本输入
- JavaScript:在调用函数的文本输入上按enter键
- jQuery自动完成功能不适用于多个文本输入
- 使用JS从选择和文本输入中捕获值,并将输出返回到HTML
- 如何通过jQuery发送选定的元素和文本输入
- HTML如何根据javascript函数的返回值限制文本输入
- jquery插件或javascript方法自动调整文本输入(而非文本区域)(固定宽度)可变高度的大小
- 在jquery中获取文本输入val始终为空
- HTML文本输入大小
- 文本输入与文本区域
- 角度ui选择标记模糊时丢失文本输入
- 文本输入值中的JavaScript变量
- Angular指令中的最佳实践是将文本输入设置为英尺和英寸的格式
- 如何在不通过模型验证的情况下屏蔽文本输入中输入的字符
- 在文本输入区域中创建双向更新
- 不使用自定义CSS或HTML(使用框架方法)的角度材质文本输入或文本区域标签大小