首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用jquery验证插件验证select

使用jquery验证插件验证select
EN

Stack Overflow用户
提问于 2013-11-03 18:21:36
回答 2查看 41.5K关注 0票数 5

我有一个默认值为-1的html select。

代码语言:javascript
复制
  <select id="BusinessDistrictId">
       <option value="-1">Select one...</option>
       //other options...
  </select>

我想强制用户选择-1 \f25 value -1以外的任何选项。我的jquery验证规则-

代码语言:javascript
复制
  rules: {
         BusinessDistrictId: { required: true , min:0}
        }

但它不起作用。有什么建议吗?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2013-11-04 01:01:19

如果你想用jQuery验证插件来验证这个元素,它的标记有两个问题...

代码语言:javascript
复制
<select id="BusinessDistrictId">
    <option value="-1">Select one...</option>
    //other options...
</select>

1)根据jQuery验证插件的要求,每个元素必须具有唯一的name属性。当规则在.validate()中声明时,它们由它们的name标识。然而,不管规则如何声明为,每个元素都必须有一个惟一的name属性,因为这是插件跟踪表单元素的方式。

2)您的min: 0规则只是对破坏的required规则的一种变通方法。为了在<select>元素上使用required: true,您必须在第一个value=""元素上具有value=""属性;因此,在本例中为时,将始终忽略required: true规则。由于您具有min: 0规则,因此您将获得类似的验证结果,该结果要求选择一个项。即使在第一个option上有value=""属性,在select元素上同时具有requiredmin规则也没有逻辑意义。

这是正确的代码。

HTML

代码语言:javascript
复制
<select id="BusinessDistrictId" name="BusinessDistrictId">
    <option value="">Select one...</option> <!-- first option contains value="" -->
    //other options...
</select>

jQuery

代码语言:javascript
复制
rules: {
    BusinessDistrictId: {  // <-- this is the name attribute
        required: true
    }
},

演示:

票数 21
EN

Stack Overflow用户

发布于 2013-11-03 19:34:28

添加name="BusinessDistrictId“解决了我的问题。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/19751898

复制
相关文章

相似问题

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