Yii2:如何使用jQuery删除所需的属性

问题描述 投票:0回答:1

我有一个textInput字段是必需的,但是当按下该复选框时,该字段不是必需的。

<div class="checkbox">
    <label>
        <?= Html::checkbox('myCheckbox', false, ['id' => 'myCheckbox']) ?>
        I don't send my address
    </label>
</div>

<?= $form->field($model, 'address')->textInput(['class' => 'form-control', 'id' => 'address']) ?>

我需要在用户选中复选框时删除所需的属性。我认为jQuery是最好的方法,所以我尝试了这个但它不起作用:

$("#myCheckbox").change(function() {
    if (this.checked) {
        $("#address").prop("required", "false");
    }
    else {
        $("#address").prop("required", "true");
    }
});

我可以看到所需的属性不在输入标记上,它在他的父标记中:

<div class="form-group field-address required has-success">
    <label class="control-label" for="address">Address</label>
    <input type="text" id="address" class="form-control" name="Form[address]" aria-required="true" aria-invalid="false">

    <div class="help-block"></div>
</div>
php jquery yii2 required requiredfieldvalidator
1个回答
0
投票

你为什么不使用whenwhenClient选项?将复选框更改为模型字段,声明名为myCheckbox的公共属性

public $myCheckbox

Form模型中,然后更改以下内容。

<div class="checkbox">
    <label>
        <?= Html::checkbox('myCheckbox', false, ['id' => 'myCheckbox']) ?>
        I don't send my address
    </label>
</div>

<div class="checkbox">
    <label>
        <?= $form->field($model,'myCheckbox')->checkbox(['uncheck'=>null,'id'=>'myCheckbox']) ?>
        I don't send my address
    </label>
</div>

然后在Form模型中的规则内执行以下操作

['address' , 'required' , 'when' => function($model) {
                    return ($model->myCheckbox!==null);
                } , 'whenClient' => 'function(attribute,value){return ($("#myCheckbox:checked").length>0)}' ] ,

希望它可以帮助你

© www.soinside.com 2019 - 2024. All rights reserved.