Maison >développement back-end >tutoriel php >Explication détaillée de la méthode pour rester sur la page actuelle après avoir ajouté, supprimé, modifié et vérifié dans Yii2

Explication détaillée de la méthode pour rester sur la page actuelle après avoir ajouté, supprimé, modifié et vérifié dans Yii2

韦小宝
韦小宝original
2017-11-28 09:20:371795parcourir

Réaliser Ajouter, Supprimer, Modifier et Vérifier restera sur la page actuelle une fois l'opération réussie, ce qui peut offrir aux utilisateurs une bonne expérience. Cependant, le framework Yii2 lui-même n'a pas pour effet de rester sur la page actuelle une fois l'opération Ajouter, Supprimer, Modifier et Vérifier réussie. Pour obtenir un tel effet, vous devez l'écrire vous-même. Mon principe est de ne pas laisser le code de base seul et de toujours m'en tenir à mes propres principes. Maintenant que j'y suis parvenu, je vais le partager. Différents chemins mènent au même objectif. S'il existe une meilleure façon de mettre en œuvre Ajouter, Supprimer, Modifier et Vérifier, n'hésitez pas à la partager.

Code d'emballage

Il y a deux fichiers ActionColumn.php et Helper.php

1 , fichier ActionColumn.php

<?php

use Closure;
use kartik\icons\Icon;
use Yii;
use yii\grid\Column;
use yii\helpers\ArrayHelper;
use yii\helpers\Html;
use yii\helpers\Url;
use common\components\Helper;

/*
*重写ActionColumn
 */
class ActionColumn extends Column
{ 
 public $buttons;

 private $defaultButtons = [];

 private $callbackButtons;
 
 public $controller;

 public $urlCreator;

 public $url_append = &#39;&#39;;

 public $appendReturnUrl = true; //默认为true,返回当前链接

 public function init()
 {
 parent::init();
 
 $this->defaultButtons = [
  [
  &#39;url&#39; => &#39;view&#39;,
  &#39;icon&#39; => &#39;eye&#39;,
  &#39;class&#39; => &#39;btn btn-success btn-xs&#39;,
  &#39;label&#39; => Yii::t(&#39;yii&#39;, &#39;View&#39;),
  &#39;appendReturnUrl&#39; => false,
  &#39;url_append&#39; => &#39;&#39;,
  &#39;keyParam&#39; => &#39;id&#39;,//是否传id,不传设置null
  ],
  [
  &#39;url&#39; => &#39;update&#39;,
  &#39;icon&#39; => &#39;pencil&#39;,
  &#39;class&#39; => &#39;btn btn-primary btn-xs&#39;,
  &#39;label&#39; => Yii::t(&#39;yii&#39;, &#39;Update&#39;),
  ],
  [
  &#39;url&#39; => &#39;delete&#39;,
  &#39;icon&#39; => &#39;trash-o&#39;,
  &#39;class&#39; => &#39;btn btn-danger btn-xs&#39;,
  &#39;label&#39; => Yii::t(&#39;yii&#39;, &#39;Delete&#39;),
  &#39;options&#39; => [
   &#39;data-action&#39; => &#39;delete&#39;,
  ],
  ]
 ];


 if (null === $this->buttons) {
  $this->buttons = $this->defaultButtons;
 } elseif ($this->buttons instanceof Closure) {
  $this->callbackButtons = $this->buttons;
 }
 }

 
 public function createUrl(
 $action,
 $model,
 $key,
 $index,
 $appendReturnUrl = null,
 $url_append = null,
 $keyParam = &#39;id&#39;,
 $attrs = []
 ) {
 if ($this->urlCreator instanceof Closure) {
  return call_user_func($this->urlCreator, $action, $model, $key, $index);
 } else {
  $params = [];
  if (is_array($key)) {
  $params = $key;
  } else {
  if (is_null($keyParam) === false) {
   $params = [$keyParam => (string)$key];
  }
  }
  $params[0] = $this->controller ? $this->controller . &#39;/&#39; . $action : $action;
  foreach ($attrs as $attrName) {
  if ($attrName === &#39;model&#39;) {
   $params[&#39;model&#39;] = $model;
  } elseif ($attrName === &#39;mainCategory.category_group_id&#39; && $model->getMainCategory()) {
   $params[&#39;category_group_id&#39;] = $model->getMainCategory()->category_group_id;
  } else {
   $params[$attrName] = $model->getAttribute($attrName);
  }
  }
  if (is_null($appendReturnUrl) === true) {
  $appendReturnUrl = $this->appendReturnUrl;
  }
  if (is_null($url_append) === true) {
  $url_append = $this->url_append;
  }
  if ($appendReturnUrl) {
  $params[&#39;returnUrl&#39;] = Helper::getReturnUrl();
  }
  return Url::toRoute($params) . $url_append;
 }
 }


 protected function renderDataCellContent($model, $key, $index)
 { 
 if ($this->callbackButtons instanceof Closure) {
  $btns = call_user_func($this->callbackButtons, $model, $key, $index, $this); 
  if (null === $btns) {
  $this->buttons = $this->defaultButtons;
  } else {
  $this->buttons = $btns;
  }
 }
 $min_width = count($this->buttons) * 34; //34 is button-width
 $data = Html::beginTag(&#39;div&#39;, [&#39;class&#39; => &#39;btn-group&#39;, &#39;style&#39; => &#39;min-width: &#39; . $min_width . &#39;px&#39;]);
 foreach ($this->buttons as $button) {
  $appendReturnUrl = ArrayHelper::getValue($button, &#39;appendReturnUrl&#39;, $this->appendReturnUrl);
  $url_append = ArrayHelper::getValue($button, &#39;url_append&#39;, $this->url_append);
  $keyParam = ArrayHelper::getValue($button, &#39;keyParam&#39;, &#39;id&#39;);
  $attrs = ArrayHelper::getValue($button, &#39;attrs&#39;, []);
  Html::addCssClass($button, &#39;btn&#39;);
  Html::addCssClass($button, &#39;btn-sm&#39;);
  $buttonText = isset($button[&#39;text&#39;]) ? &#39; &#39; . $button[&#39;text&#39;] : &#39;&#39;; 
  $data .= Html::a(
   $button[&#39;label&#39;] . $buttonText,
   $url = $this->createUrl(
   $button[&#39;url&#39;],
   $model,
   $key,
   $index,
   $appendReturnUrl,
   $url_append,
   $keyParam,
   $attrs
   ),
   ArrayHelper::merge(
   isset($button[&#39;options&#39;]) ? $button[&#39;options&#39;] : [],
   [
    //&#39;data-pjax&#39; => 0,
    // &#39;data-action&#39; => $button[&#39;url&#39;],
    &#39;class&#39; => $button[&#39;class&#39;],
    &#39;title&#39; => $button[&#39;label&#39;],
   ]
   )
  ) . &#39; &#39;;
 }
 $data .= &#39;</div>&#39;; 
 return $data;
 }

}

2. Fichier Helper.php

<?php

use Yii;

class Helper
{ 
 private static $returnUrl;
 public static $returnUrlWithoutHistory = false;

 /**
 * @param int $depth
 * @return string
 */
 public static function getReturnUrl()
 {
 if (is_null(self::$returnUrl)) {
  $url = parse_url(Yii::$app->request->url);
  $returnUrlParams = [];
  if (isset($url[&#39;query&#39;])) {
  $parts = explode(&#39;&&#39;, $url[&#39;query&#39;]);
  foreach ($parts as $part) {
   $pieces = explode(&#39;=&#39;, $part);
   if (static::$returnUrlWithoutHistory && count($pieces) == 2 && $pieces[0] === &#39;returnUrl&#39;) {
   continue;
   }
   if (count($pieces) == 2 && strlen($pieces[1]) > 0) {
   $returnUrlParams[] = $part;
   }
  }
  }
  if (count($returnUrlParams) > 0) {
  self::$returnUrl = $url[&#39;path&#39;] . &#39;?&#39; . implode(&#39;&&#39;, $returnUrlParams);
  } else {
  self::$returnUrl = $url[&#39;path&#39;];
  }
 }
 return self::$returnUrl;
 }
}

Afficher l'appel

1. Appelez-le directement et remplacez le ['class' => 'yiigridActionColumn'] fourni avec Yii2 par notre nouveau ['class' => 'commoncomponentsActionColumn'].

2. Si l'appel direct ne peut pas répondre à vos exigences, vous pouvez personnaliser le lien. Le lien personnalisé est écrit comme suit :

[
 &#39;class&#39; => &#39;common\components\ActionColumn&#39;,
 &#39;urlCreator&#39; => function($action, $model, $key, $index) use ($id) {
 //自定义链接传的参数
 $params = [
  $action,
  &#39;option_id&#39; => $model->option_id, 
  &#39;id&#39; => $id,
 ];
 $params[&#39;returnUrl&#39;] = common\components\Helper::getReturnUrl();
 return yii\helpers\Url::toRoute($params);
 },
 &#39;buttons&#39; => [
   [
   &#39;url&#39; =>&#39;view&#39;,
   &#39;class&#39; => &#39;btn btn-success btn-xs&#39;,
   &#39;label&#39; => Yii::t(&#39;yii&#39;, &#39;View&#39;),
   &#39;appendReturnUrl&#39; => false,//是否保留当前URL,默认为true
   &#39;url_append&#39; => &#39;&#39;,
   &#39;keyParam&#39; => &#39;id&#39;, //是否传id,不传设置null
   ],
   [
   &#39;url&#39; => &#39;update&#39;,
   &#39;class&#39; => &#39;btn btn-primary btn-xs btn-sm&#39;,
   &#39;label&#39; => Yii::t(&#39;yii&#39;, &#39;Update&#39;),
   &#39;appendReturnUrl&#39; => true,//是否保留当前URL,默认为true
   &#39;url_append&#39; => &#39;&#39;,
   &#39;keyParam&#39; => &#39;id&#39;, //是否传id,不传设置null
   ],
   [
   &#39;url&#39; => &#39;delete&#39;,
   &#39;class&#39; => &#39;btn btn-danger btn-xs btn-sm&#39;,
   &#39;label&#39; => Yii::t(&#39;yii&#39;, &#39;Delete&#39;),
   &#39;options&#39; => [
   &#39;data-action&#39; => &#39;delete&#39;,
   ],
   &#39;appendReturnUrl&#39; => true,//是否保留当前URL,默认为true
   &#39;url_append&#39; => &#39;&#39;,
   &#39;keyParam&#39; => &#39;id&#39;, //是否传id,不传设置null
   ],
 ],

],

3. un, citez-le comme ceci :

<?= Html::a(Yii::t(&#39;yii&#39;, &#39;Create&#39;), [&#39;create&#39;,&#39;returnUrl&#39; => Helper::getReturnUrl()], [&#39;class&#39; => &#39;btn btn-success&#39;]) ?> 。

ContrôleurLogique

1. obtenez returnUrl, code : $returnUrl = Yii::$app->request->get('returnUrl');

2. L'URL vers laquelle accéder : return $this->redirect($returnUrl);.

Résumé de l'analyse

1. L'avantage de cette méthode est que le code principal n'est pas laissé seul et que la méthode appelante conserve la méthode intégrée Yii2.

2. L'inconvénient est que lors de la personnalisation du lien, vous devez écrire chaque opération de mise à jour, d'affichage et de suppression. Vous ne pouvez pas utiliser ce 'modèle' => }{delete}' est simple et confortable à regarder. Vous pouvez l'écrire selon vos besoins.

D'accord, c'est tout le contenu de cet article. J'espère que le contenu de cet article pourra être utile aux études ou au travail de chacun. Si vous avez des questions, vous pouvez laisser un message pour communiquer.

Ce qui précède est une explication détaillée de la méthode pour rester sur la page actuelle après avoir ajouté, supprimé, modifié et vérifié dans Yii2. Bienvenue pour discuter et échanger des problèmes dans la Communauté du site Web chinois PHP. !

Recommandations associées :

Explication détaillée des méthodes d'enregistrement et de création de composants dans Yii2

Comment Yii2 utilise la dénomination Camel Case pour accéder aux instances du contrôleur

Code d'implémentation pour la fonction de génération de code QR du framework Yii2.0

Comment implémenter les fonctions de connexion automatique et de connexion et de déconnexion du framework Yii2

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn