En este capítulo veremos los pasos a seguir para poder validar formularios mediante la tecnología AJAX en Yii2. #yii2 #php #ajax
El código de cada archivo del capítulo lo podéis ver a continuación:
Vista validarformularioajax.php
Validar Formulario Ajax
"post", "id" => "formulario", "enableClientValidation" => false, "enableAjaxValidation" => true, ]); ?>
field($model, "nombre")->input("text") ?>field($model, "email")->input("email") ?>"btn btn-primary"]) ?> end() ?>
Modelo ValidarFormularioAjax.php
<?php namespace app\models; use Yii; use yii\base\model; class ValidarFormularioAjax extends model{ public $nombre; public $email; public function rules() { return [ ['nombre', 'required', 'message' => 'Campo requerido'], ['nombre', 'match', 'pattern' => "/^.{3,50}$/", 'message' => 'Mínimo 3 y máximo 50 caracteres'], ['nombre', 'match', 'pattern' => "/^[0-9a-z]+$/i", 'message' => 'Sólo se aceptan letras y números'], ['email', 'required', 'message' => 'Campo requerido'], ['email', 'match', 'pattern' => "/^.{5,80}$/", 'message' => 'Mínimo 5 y máximo 80 caracteres'], ['email', 'email', 'message' => 'Formato no válido'], ['email', 'email_existe'] ]; } public function attributeLabels() { return [ 'nombre' => 'Nombre:', 'email' => 'Email:', ]; } public function email_existe($attribute, $params) { $email = ["manuel@mail.com", "antonio@mail.com"]; foreach($email as $val) { if($this->email == $val) { $this->addError($attribute, "El email seleccionado existe"); return true; } else { return false; } } } }
Controlador SiteController.php
<?php namespace app\controllers; use Yii; use yii\filters\AccessControl; use yii\web\Controller; use yii\filters\VerbFilter; use app\models\LoginForm; use app\models\ContactForm; use app\models\ValidarFormulario; use app\models\ValidarFormularioAjax; use yii\widgets\ActiveForm; use yii\web\Response; class SiteController extends Controller { public function actionSaluda($get = "Tutorial Yii") { $mensaje = "Hola Mundo"; $numeros = [0, 1, 2, 3, 4, 5]; return $this->render("saluda", [ "saluda" => $mensaje, "numeros" => $numeros, "get" => $get, ]); } public function actionFormulario($mensaje = null) { return $this->render("formulario", ["mensaje" => $mensaje]); } public function actionRequest() { $mensaje = null; if (isset($_REQUEST["nombre"])) { $mensaje = "Bien, has enviando tu nombre correctamente: " . $_REQUEST["nombre"]; } $this->redirect(["site/formulario", "mensaje" => $mensaje]); } public function actionValidarformulario() { $model = new ValidarFormulario; if ($model->load(Yii::$app->request->post())) { if($model->validate()) { //Por ejemplo, consultar en una base de datos } else { $model->getErrors(); } } return $this->render("validarformulario", ["model" => $model]); } public function actionValidarformularioajax() { $model = new ValidarFormularioAjax; $msg = null; if ($model->load(Yii::$app->request->post()) && Yii::$app->request->isAjax) { Yii::$app->response->format = Response::FORMAT_JSON; return ActiveForm::validate($model); } if ($model->load(Yii::$app->request->post())) { if ($model->validate()) { //Por ejemplo hacer una consulta a una base de datos $msg = "Enhorabuena formulario enviado correctamente"; $model->nombre = null; $model->email = null; } else { $model->getErrors(); } } return $this->render("validarformularioajax", ['model' => $model, 'msg' => $msg]); } public function behaviors() { return [ 'access' => [ 'class' => AccessControl::className(), 'only' => ['logout'], 'rules' => [ [ 'actions' => ['logout'], 'allow' => true, 'roles' => ['@'], ], ], ], 'verbs' => [ 'class' => VerbFilter::className(), 'actions' => [ 'logout' => ['post'], ], ], ]; } public function actions() { return [ 'error' => [ 'class' => 'yii\web\ErrorAction', ], 'captcha' => [ 'class' => 'yii\captcha\CaptchaAction', 'fixedVerifyCode' => YII_ENV_TEST ? 'testme' : null, ], ]; } public function actionIndex() { return $this->render('index'); } public function actionLogin() { if (!\Yii::$app->user->isGuest) { return $this->goHome(); } $model = new LoginForm(); if ($model->load(Yii::$app->request->post()) && $model->login()) { return $this->goBack(); } else { return $this->render('login', [ 'model' => $model, ]); } } public function actionLogout() { Yii::$app->user->logout(); return $this->goHome(); } public function actionContact() { $model = new ContactForm(); if ($model->load(Yii::$app->request->post()) && $model->contact(Yii::$app->params['adminEmail'])) { Yii::$app->session->setFlash('contactFormSubmitted'); return $this->refresh(); } else { return $this->render('contact', [ 'model' => $model, ]); } } public function actionAbout() { return $this->render('about'); } }
Ver el vídeo tutorial de Yii Framework 2 en Youtube
2 comentarios:
Olá, sou brasileiro. Parabéns pelas aulas. Estou aprendendo bem.
acredito que você colou a view com alguns erros. Corrigi aqui mas não consigo enviar pois o blogger não permite tags html no comentário.
Outra coisa, a função email_existe() está com um problema. Ela só verifica o primeiro email do vetor. Fiz uma correção. Segue abaixo:
public function email_existe($attribute, $params)
{
$email = ["manuel@mail.com", "antonio@mail.com"];
$erro = 0;
foreach($email as $val)
{
if($this->email == $val)
{
$this->addError($attribute, "El email seleccionado existe");
$erro = 1;
}
}
if($erro == 0)
return false;
else
return true;
}
O de otra manera (modificando un poco el comentario anterior)
return $erro==0?true:false;
Publicar un comentario