jquery - 如何动态添加和删除要由 Parsley.js 验证的表单字段?

标签 jquery validation dynamic parsley.js

我有一个表单('#registrations'),我正在使用 Parsley.js 进行验证,到目前为止它工作正常。但是,我正在尝试动态删除表单字段并将新字段添加到欧芹验证中,具体取决于某人在选择下拉列表中选择的内容(“#manufacturer”)。

这是我的标记:

<select name="manufacturer" id="manufacturer" parsley-required="true" data-error-message="Please select a manufacturer.">

    <option value="apple">Apple</option>

    <option value="blackberry">Blackberry</option>

    <option value="htc">HTC</option>

    <option value="huawei">Huawei</option>

    <option value="lg">LG</option>

    <option value="motorola">Motorola</option>

    <option value="nokia">Nokia</option>

    <option value="samsung">Samsung</option>

    <option value="sony">Sony</option>

    <option value="sony-ericsson">Sony Ericsson</option>

</select>

这是我的 JS:

//init parsley
$('#registrations').parsley();

$('#manufacturer').change(function() {

        //define selected value
        var manufacturer = $(this).val();

        //destroy parsley
        $('#registrations').parsley('destroy');

        //remove all models selects from parsley validation
        //if someone has previously selected a different manufacturer
        $('#registrations').parsley('removeItem', '#apple-models');
        $('#registrations').parsley('removeItem', '#blackberry-models');
        $('#registrations').parsley('removeItem', '#htc-models');
        $('#registrations').parsley('removeItem', '#huawei-models');
        $('#registrations').parsley('removeItem', '#lg-models');
        $('#registrations').parsley('removeItem', '#motorola-models');
        $('#registrations').parsley('removeItem', '#nokia-models');
        $('#registrations').parsley('removeItem', '#samsung-models');
        $('#registrations').parsley('removeItem', '#sony-models');
        $('#registrations').parsley('removeItem', '#sony-ericsson-models');

        //add corresponding models select to parsely
        $('#registrations').parsley('addItem', '#'+manufacturer+'-models');

        //reinit parsley
        $('#registrations').parsley();

    });

这不起作用,但我不知道为什么。

最佳答案

将新字段添加到 Parsley 后,您需要向该字段添加所需的约束。

//add corresponding models select to parsely
$('#registrations').parsley('addItem', '#'+manufacturer+'-models');

//add required constraint 
$('#'+manufacturer+'-models').parsley('addConstraint', {
    required: true 
});

更新(2014 年 4 月 10 日)

以上适用于 Parsley.js 1.x,但不适用于 Parsley 2.x。

Parsley 2.x 不使用 addItemremoveItemaddConstraintremoveConstraint

相反,Parsley 2.x 将根据每个输入的数据属性自动检测表单中的更改。在上面的示例中,如果您想向 Parsley 添加新项目,您将执行以下操作:

//destroy parsley
$('form').parsley().destroy();

//set required attribute on input to true
$('input').attr('data-parsley-required', 'true');

//reinitialize parsley
$('form').parsley();

同样,如果您想从欧芹中删除某个项目,您可以这样做:

//destroy parsley
$('form').parsley().destroy();

//set required attribute on input to false
$('input').attr('data-parsley-required', 'false');

//reinitialize parsley
$('form').parsley();

关于jquery - 如何动态添加和删除要由 Parsley.js 验证的表单字段?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21867162/

相关文章:

php - eventResize 不适用于 fullCalendar2.6*

jquery初始化函数

jquery 使用 .each() 递增数字

javascript - 如何通过 jquery 提交时使用 onclick 事件验证 ajax 表单?

objective-c - NSInvocation 类上的 setSelector 方法的目的是什么?

C++ 存储输入行

javascript - 专注于输入并使用 Jquery 移除焦点

java - 我正在尝试验证一些代码以仅获得 0-100 而没有字母

javascript - 密码验证脚本不起作用

php - 使用 PHP 动态显示选项值