Ajax 模态 window yii2 中的验证数据
Ajax validation data in modal window yii2
我的主视图中有模态window
<?php
Modal::begin([
'header' => 'Log in or register or restore password',
'id' => 'modal',
'size' => 'modal-lg',
]);
echo "<div id='modalContent'></div>";
Modal::end();
?>
而且我还有其他视图可以在主视图window 的模态window 中呈现它
<div class="row">
<div class="col-lg-5">
<?php $form = ActiveForm::begin(['id' => 'login-form']); ?>
<?= $form->field($login_model, 'username')->textInput() ?>
<?= $form->field($login_model, 'password')->passwordInput() ?>
<div class="form-group">
<?= Html::submitButton('Login', ['class' => 'btn btn-primary', 'name' => 'login-button', 'data-pjax' => 1]) ?>
</div>
<?php ActiveForm::end(); ?>
</div>
</div>
使用这个
\frontend\assets\OverviewAsset::register($this);
我注册了我的js代码
$(document).ready(function() {
$(function() {
var id_user_tag = 'id_user';
$(document).on('click','[' + id_user_tag + ']', function () {
var id_user = this.getAttribute(id_user_tag);
$.ajax({
url: '/client/is-full-page-accessed',
type: 'post',
data: {
id_user: id_user
},
success: function (response) {
if(response) {
window.location = 'full-page?id_user=' + id_user;
} else {
$.get(
'/client/log-in',
function (data) {
$('#modal').modal('show')
.find('#modalContent')
.html(data);
}
);
}
}
});
});
});});
我有控制器
public function actionLogIn()
{
if (!\Yii::$app->user->isGuest) {
return $this->goHome();
}
$password_reset_request_model = new PasswordResetRequestForm();
if ($password_reset_request_model->load(Yii::$app->request->post()) && $password_reset_request_model->validate()) {
if ($password_reset_request_model->sendEmail()) {
Yii::$app->session->setFlash('success', 'Check your email for further instructions.');
return $this->goHome();
} else {
Yii::$app->session->setFlash('error', 'Sorry, we are unable to reset password for email provided.');
}
}
$login_model = new LoginForm();
if ($login_model->load(Yii::$app->request->post()) && $login_model->login()) {
return $this->goBack();
} else {
$model['login'] = $login_model;
return $this->renderAjax('log-in', ['login_model' => $login_model, 'password_reset_request_model' => $password_reset_request_model]);
}
}
所以我终于拥有了
我点击某个按钮,如果我没有登录 - 我必须打开我的模式 window 并获取我在控制器中呈现的附加视图。它有效,但是当我在模态 window 中输入错误数据时 - 我的页面转到此 /client/log-in
URL。但我想以模式 window 显示我的无效数据。
怎么做?
如果需要任何其他信息,请告诉我。
再次抱歉。我的错。我只需要将我的表格填入
<?php yii\widgets\Pjax::begin(['id' => 'log-in']) ?>
<?php $form = ActiveForm::begin(['id' => 'login-form', 'options' => ['data-pjax' => true]]); ?>
<?php yii\widgets\Pjax::end() ?>
这就是我所做的所有更改。文档、文档和另一份文档!
我的主视图中有模态window
<?php
Modal::begin([
'header' => 'Log in or register or restore password',
'id' => 'modal',
'size' => 'modal-lg',
]);
echo "<div id='modalContent'></div>";
Modal::end();
?>
而且我还有其他视图可以在主视图window 的模态window 中呈现它
<div class="row">
<div class="col-lg-5">
<?php $form = ActiveForm::begin(['id' => 'login-form']); ?>
<?= $form->field($login_model, 'username')->textInput() ?>
<?= $form->field($login_model, 'password')->passwordInput() ?>
<div class="form-group">
<?= Html::submitButton('Login', ['class' => 'btn btn-primary', 'name' => 'login-button', 'data-pjax' => 1]) ?>
</div>
<?php ActiveForm::end(); ?>
</div>
</div>
使用这个
\frontend\assets\OverviewAsset::register($this);
我注册了我的js代码
$(document).ready(function() {
$(function() {
var id_user_tag = 'id_user';
$(document).on('click','[' + id_user_tag + ']', function () {
var id_user = this.getAttribute(id_user_tag);
$.ajax({
url: '/client/is-full-page-accessed',
type: 'post',
data: {
id_user: id_user
},
success: function (response) {
if(response) {
window.location = 'full-page?id_user=' + id_user;
} else {
$.get(
'/client/log-in',
function (data) {
$('#modal').modal('show')
.find('#modalContent')
.html(data);
}
);
}
}
});
});
});});
我有控制器
public function actionLogIn()
{
if (!\Yii::$app->user->isGuest) {
return $this->goHome();
}
$password_reset_request_model = new PasswordResetRequestForm();
if ($password_reset_request_model->load(Yii::$app->request->post()) && $password_reset_request_model->validate()) {
if ($password_reset_request_model->sendEmail()) {
Yii::$app->session->setFlash('success', 'Check your email for further instructions.');
return $this->goHome();
} else {
Yii::$app->session->setFlash('error', 'Sorry, we are unable to reset password for email provided.');
}
}
$login_model = new LoginForm();
if ($login_model->load(Yii::$app->request->post()) && $login_model->login()) {
return $this->goBack();
} else {
$model['login'] = $login_model;
return $this->renderAjax('log-in', ['login_model' => $login_model, 'password_reset_request_model' => $password_reset_request_model]);
}
}
所以我终于拥有了
我点击某个按钮,如果我没有登录 - 我必须打开我的模式 window 并获取我在控制器中呈现的附加视图。它有效,但是当我在模态 window 中输入错误数据时 - 我的页面转到此 /client/log-in
URL。但我想以模式 window 显示我的无效数据。
怎么做?
如果需要任何其他信息,请告诉我。
再次抱歉。我的错。我只需要将我的表格填入
<?php yii\widgets\Pjax::begin(['id' => 'log-in']) ?>
<?php $form = ActiveForm::begin(['id' => 'login-form', 'options' => ['data-pjax' => true]]); ?>
<?php yii\widgets\Pjax::end() ?>
这就是我所做的所有更改。文档、文档和另一份文档!