使用Jquery选择所有具有相同数据属性名称的元素

5

我想使用jQuery选择表单中所有具有类似名称的数据属性的输入框。

这是我的表单:

<form id = "myForm">
  <input name="name" data-valid-presence=true >
  <input name="age" data-valid-biggerThan="18" >
  <input name="email[0]" data-valid-email=true >
  <input name="email[1]" data-valid-email=true >
</form>

我的 jQuery 选择器是:

var inputs = jQuery("#myForm").find("input[data-valid-email],[data-valid-length],[data-valid-presence], [data-valid-biggerThan]");

我正在寻找一种方法来选择所有带有 data-valid-* 的输入框,而不需要像这样逐个查找它们。 有什么想法吗?
1个回答

1
你可以使用jQuery.filter:
var inputs = $('form').find('input').filter(function() {
    var matched = false;
    $.each(this.attributes, function(attr) {
        if ( matched ) return;
        matched = /^data-valid/.test(this.name);
    });
    return matched;
});

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接