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