在我的代码中我有一个字段(例如字段名称是 exampleField [] ),其中我通过JS实现添加更多功能。现在,我想实现Yii2每个字段上必需的Validtor 。我已经使用每个验证器但它不起作用。我的yii2版本是2.0.6。先谢谢
这是我的javascript代码
var max_fields = 4; //maximum input boxes allowed
var wrapper = $(".addAmount"); //Fields wrapper
var add_button = $(".add_field_button"); //Add button ID
var html = '';
var x = <?php echo $count ?>; //initlal text box count
$(add_button).click(function (e) { //on add input button click
html = '<div id="multipleRow' + x + '"><div class="fullwidth">';
html += '<div class="span4"><div class="control-group">';
html += '<label for="plandetail-planduration" class="control-label">Duration <span class="required">*</span></label>';
html += '<div class="controls"><div class="form-group field-plandetail-planduration required">';
html += '<input type="text" name="PlanDetail[planDuration][]" class="form-control" id="plandetail-planduration">';
html += '<div class="error"></div></div></div></div>';
html += '</div>';
html += '<div class="span4"><div class="control-group">';
html += '<label for="plandetail-plandurationtype" class="control-label">Duration Period<span class="required">*</span></label>';
html += '<div class="controls"><div class="form-group field-plandetail-plandurationtype">';
html += '<select name="PlanDetail[planDurationType][]" class="form-control" id="plandetail-plandurationtype">';
html += '<option value=""></option>';
html += '<option value="month">Month</option>';
html += '<option value="year">Year</option>';
html += '</select>';
html += '<div class="help-block"></div>';
html += '</div></div></div></div></div>';
html += '<div class="fullwidth">';
html += '<div class="span4"><div class="control-group">';
html += '<label for="plandetail-planamount" class="control-label">Amount <span class="required">*</span></label>';
html += '<div class="controls"><div class="form-group field-plandetail-planamount required">';
html += '<input type="text" name="PlanDetail[planAmount][]" class="form-control" id="plandetail-planamount">';
html += '<div class="error"></div>';
html += '</div></div>';
html += '</div></div>';
html += '<div class="span4"><div class="control-group">';
html += '<label for="plandetail-plandiscountamount" class="control-label">Discount Amount <span class="required">*</span></label>';
html += '<div class="controls"><div class="form-group field-plandetail-plandiscountamount required">';
html += '<input type="text" name="PlanDetail[planDiscountAmount][]" class="form-control" id="plandetail-plandiscountamount">';
html += '<div class="error"></div>';
html += '</div></div>';
html += '</div></div>';
html += '<div class="span4"><div class="control-group">';
html += '<label for="plandetail-plancurrency" class="control-label">Currency <span class="required">*</span></label>';
html += '<div class="controls"><div class="form-group field-plandetail-plancurrency required">';
html += '<select name="PlanDetail[planCurrency][]" class="form-control" id="plandetail-plancurrency">';
html += '<option value=""></option><option value="USD">USD</option><option value="EUR">EUR</option>';
html += '</select>';
html += '<div class="help-block"></div>';
html += '</div></div>';
html += '</div></div>';
html += '</div>';
html += '<div class="col-lg-4"><a href="javascript:void(0)" class="remove_field" id="' + x + '">Remove</a></div>';
html += '</div></div>';
e.preventDefault();
if (x < max_fields) { //max input box allowed
x++; //text box increment
$(wrapper).append(html); //add input box
}else{alert('You Can not add more than 4 Amount')}
});
$(wrapper).on("click", ".remove_field", function (e) { //user click on remove text
e.preventDefault();
// alert(this.id);
$("#multipleRow" + this.id).remove();
x--;
});
答案 0 :(得分:0)
您只是添加了html
个输入,并且错过了进行验证的js
。您必须使用yiiActiveForm添加所有动态字段。以下是基本模板附带的联系表单的示例:
首先,从表单中删除字段电子邮件,以便我们可以使用js
添加后者:
<?php // $form->field($model, 'email') ?>
确保您在表单中使用ajax验证:
<?php $form = ActiveForm::begin(['id' => 'contact-form', 'enableAjaxValidation' => true]); ?>
现在,在视图的最后添加以下代码:
<?php
$js = <<<JS
$( document ).ready(function() {
var input = '<div class="form-group field-contactform-email required">' +
'<label class="control-label" for="contactform-email">Email</label>' +
'<input type="text" id="contactform-email" class="form-control" name="ContactForm[email]">' +
'<p class="help-block help-block-error"></p>' +
'</div>';
$('#contact-form').append(input); // add the html in the form
$('#contact-form').yiiActiveForm('add', { // add the js rules to the form
'id': 'contactform-email',
'name': 'email',
'container': '.field-contactform-email',
'input': '#contactform-email',
'enableAjaxValidation':true
});
});
JS;
$this->registerJs($js); // insert javascript
最后,我们只需要在控制器中创建ajax validation,例如:
use yii\web\Response;
use yii\widgets\ActiveForm;
class SiteController extends Controller
{
...
public function actionContact()
{
$model = new ContactForm();
if ($model->load(Yii::$app->request->post())) { // load the post
if (Yii::$app->request->isAjax) { // verify is ajax
Yii::$app->response->format = Response::FORMAT_JSON; // change the response to json format
return ActiveForm::validate($model); // return the validation as json
} elseif ($model->contact(Yii::$app->params['adminEmail'])) {
Yii::$app->session->setFlash('contactFormSubmitted');
return $this->refresh();
}
}
return $this->render('contact', [
'model' => $model,
]);
}
}