Heim  >  Artikel  >  Backend-Entwicklung  >  Fallstudie der Dropdown-Box-Suchfunktion in der yii2-Komponente

Fallstudie der Dropdown-Box-Suchfunktion in der yii2-Komponente

黄舟
黄舟Original
2017-09-09 09:19:001825Durchsuche

In diesem Artikel wird hauptsächlich der Beispielcode der yii2-Komponenten-Dropdown-Box mit Suchfunktion (yii-select2) vorgestellt, der einen bestimmten Referenzwert hat. Interessierte können sich darüber informieren.

Einfache kleine Funktion , aber es macht ziemlich viel Spaß, es zu benutzen. Teilen Sie es, damit sich mehr Menschen schneller entwickeln und glücklich programmieren können.

Wenn Sie Composer noch nicht verwendet haben, schauen Sie sich mein Tutorial an. Composer ist einfach ein Muss und magisch. Nachdem das gesagt ist, lassen Sie uns schnell Composer verwenden, um es zu installieren.

Keine Eile, werfen wir zunächst einen Blick auf die Darstellungen, sonst haben Sie keine Lust oder Lust, weiterzulesen.

Was zum Teufel, kein Interesse? Lesen Sie einfach weiter. Erst dann können Sie die Vorteile spüren, nachdem Sie es gelesen haben.

Es fühlt sich sehr gut an, ist aber noch viel mehr als das. Es ist auch sehr hochwertig und die Wirkung ist erstaunlich.

Okay, okay, beeilen Sie sich und installieren Sie es, sonst wird der Chat endlos.

composer require kartik-v/yii2-widget-select2 "@dev"

Besonderer Hinweis, da die hier installierte Entwicklerversion, die Entwicklungsversion, eine instabile Version ist. Wenn Ihr Projekt auf Git gehostet wird, Composer Denken Sie nach der Installation daran, die .git-Datei im Verzeichnis sellerkartik-vyii2-widget-select2 zu löschen, da Sie sie sonst nicht senden können.
Warten Sie etwa 5 Minuten, dann wird sie installiert Beginnen Sie mit der Verwendung wie folgt. Manchmal muss es standardmäßig ausgewählt werden, einfach zu handhaben, einfach Mehrwert hinzufügen

//如果你的表单是ActiveForm,请使用

use kartik\select2\Select2; 
//$data是键值对数组哦,key-value ,下面所声明的所有$data均为键值对数组,以该数组为例 
$data = [2 => 'widget', 3 => 'dropDownList', 4 => 'yii2']; 
echo $form->field($model, 'title')->widget(Select2::classname(), [ 
  'data' => $data, 
  'options' => ['placeholder' => '请选择 ...'], 
]);

Aber wenn Ihr Formular von ActiveForm generiert wird , aber oft sind die Felder keine Tabellen. Was tun mit Feldern? Im obigen Beispiel müssen Sie nur angeben: $model->title = ['title1', 'title2'];

//如果你的表单是非ActiveForm,可以参考下面的

use kartik\select2\Select2; 
echo Select2::widget([ 'name' => 'title', 
  'data' => $data, 
  'options' => ['placeholder' => '请选择...'] 
]);
Das ist im Grunde alles, was wir tun werden. Es ist sehr einfach zu implementieren die Dropdown-Auswahl- und Suchfunktion. Es ist jedoch wieder ein „Aber“ aufgetaucht, aber das ist es, was wir gerade gedacht haben: „Können Sie die Bedienung bequemer gestalten? Können Sie mehr auswählen?“ Ah? Um Ihren ZB-Trick umzusetzen, ist er in der Tat einfach und kann mit einer Codezeile gelöst werden.

use kartik\select2\Select2; 
echo Select2::widget([ 
  'name' => 'title', 
  'value' => 2, 
  'data' => $data, 
  'options' => ['placeholder' => '请选择...'] 
]);
Mir ist aufgefallen, dass eine Mehrfachoption hinzugefügt wurde. Formulare, die von Nicht-ActiveForm generiert wurden, funktionieren auf die gleiche Weise.

Mal sehen, was der Effekt ist.

An diesem Punkt können wir NBs Lieder singen und glücklich nach Hause gehen

echo $form->field($model, 'title')->widget(Select2::classname(), [ 
  'data' => $data, 
  'options' => ['multiple' => true, 'placeholder' => '请选择 ...'], 
]);
#多选的添加默认值同上
Warten Sie, ich scheine etwas vergessen zu haben, alle scharfäugigen Freunde. Sie mögen Ich habe festgestellt, dass es sich bei $data um alle Daten handelt, die wir im Voraus vorbereitet haben. Sie sagten, wenn die Datenmenge groß ist, werden wir sehen, wie man asynchrone Suchergebnisse implementiert. Zum Beispiel möchten wir jetzt einen bestimmten Buchtitel abfragen, aber das Datenvolumen unseres Buches beträgt etwa 1 Million. Dies erfordert, dass wir die Daten im Dropdown-Feld basierend auf Ihren Suchergebnissen abrufen. Fortsetzung folgt, weitere Erläuterungen folgen später.

Kommt mal, lasst uns einen Blick darauf werfen, wie man die asynchrone Suchfunktion bei der Arbeit verwendet, besonders beim Korrelieren von Daten. Es ist einfach Verwendung. Unglaublich.

Ich werde nicht näher auf die grundlegende Verwendung eingehen. Bitte lesen Sie das oben Gesagte, wir werden hier weiter reden.

Sehen wir uns zunächst eine Vorschau der Darstellung der asynchronen Suche an

Beachten Sie, dass die markierten Teile im Bild anhand der von uns eingegebenen Schlüsselwörter durchsucht werden asynchron, ich schätze, Sie können den Effekt nicht sehen, wenn ich einen Screenshot mache. Ich weiß nicht, wie man das macht Die Leute verstehen es. Das nennt man nur möglich, aber ich kann es nicht in Worte fassen. Okay, gehen wir einfach direkt zum Code und sehen uns die spezifische Operation an.

Der obige Code kann kopiert und direkt verwendet werden. Das einzige, was geändert werden muss, ist die entsprechende URL-Adresse in Ajax. Werfen wir einen Blick darauf, wie der Controller-Layer-Code Daten bereitstellt.

Das obige ist der detaillierte Inhalt vonFallstudie der Dropdown-Box-Suchfunktion in der yii2-Komponente. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn