成人精品一区二区三区中文字幕-成人精品一区二区三区-成人精品一级毛片-成人精品亚洲-日本在线视频一区二区-日本在线视频免费

導航首頁 ? 技術(shù)教程 ? yii2組件之下拉框帶搜索功能的示例代碼(yii-select2)
全站頭部文字 我要出現(xiàn)在這里
yii2組件之下拉框帶搜索功能的示例代碼(yii-select2) 679 2023-12-10   

簡單的小功能,但是用起來還是蠻爽的。分享出來讓更多的人有更快的開發(fā)效率,開開心心快樂編程。

如果你還沒有使用過composer,你可就out了,看我的教程分享,composer簡直就是必備神奇有木有。都說到這個點上了,我們趕緊使用composer進行安裝吧。

不急,先來看看效果圖是啥樣的,不然都沒心情沒欲望看下去。

查看圖片

啥玩意,不感興趣?繼續(xù)看嘛,看完再操作一邊才能覺得好在哪里。

有木有感覺很帥氣,當然啦,遠遠不止,還很上檔次用起來效果也是杠杠的有木有。

好了好了,抓緊時間安裝,不然聊起來真是沒完沒了。

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

特別說明,因為這里安裝的dev版本,也就是開發(fā)版本,不穩(wěn)定版本,如果你的項目是git托管的,composer安裝下來之后這里記得刪掉 vendorkartik-vyii2-widget-select2目錄下的.git文件,不然你提交不上去的哦
等他個大概5分鐘的樣子差不多了,安裝就好了,然后我們就可以像下面一樣開始使用了

//如果你的表單是ActiveForm,請使用

use kartikselect2Select2; 
//$data是鍵值對數(shù)組哦,key-value ,下面所聲明的所有$data均為鍵值對數(shù)組,以該數(shù)組為例 
$data = [2 => 'widget', 3 => 'dropDownList', 4 => 'yii2']; 
echo $form->field($model, 'title')->widget(Select2::classname(), [ 
  'data' => $data, 
  'options' => ['placeholder' => '請選擇 ...'], 
]);
//如果你的表單是非ActiveForm,可以參考下面的

use kartikselect2Select2; 
echo Select2::widget([ 'name' => 'title', 
  'data' => $data, 
  'options' => ['placeholder' => '請選擇...'] 
]);

非ActiveFomr生成的更新數(shù)據(jù)的時候就需要默認選中,好辦,加value值即可

use kartikselect2Select2; 
echo Select2::widget([ 
  'name' => 'title', 
  'value' => 2, 
  'data' => $data, 
  'options' => ['placeholder' => '請選擇...'] 
]);

但是如果你的表單是ActiveForm生成的,但是往往字段不是表字段怎么辦呢?更好辦啦,以上面的為例,你只需要指定$model->title = ['title1', 'title2'];即可

基本上就是這么回事,我們也就很簡單的實現(xiàn)了下拉選擇并可搜索的功能。但是,咋又冒出來了個但是呢,但是剛才是我們想的,事實是這樣的,小編妹子說了,你這能不能操作再方便點,一次選擇一個太麻煩了,能不能多選呀?為了實現(xiàn)你那ZB的伎倆,好吧,確實也簡單,一行代碼解決掉。

echo $form->field($model, 'title')->widget(Select2::classname(), [ 
  'data' => $data, 
  'options' => ['multiple' => true, 'placeholder' => '請選擇 ...'], 
]);
#多選的添加默認值同上

眼尖的注意到了,加了一個multiple選項。非ActiveForm生成的表單操作一致。

我們看看效果是怎么樣的。

查看圖片

到此,我們已經(jīng)可以唱者NB的歌歡快的回家了

等等,好像忘記什么了,有眼尖的小伙伴可能注意到了,$data都是我們預先準備好的數(shù)據(jù),你說這數(shù)據(jù)量萬一很大的情況,不搞死人了嘛,那接下來讓我們看看如何實現(xiàn)異步搜索結(jié)果。舉一個例子,我們現(xiàn)在要查詢某一個書名,但是我們的書的數(shù)據(jù)量大概有100W,很簡單,這需要我們根據(jù)你的搜索結(jié)果異步獲取下拉框里面的數(shù)據(jù)。未完待續(xù),晚點做進一步說明。

來,上家伙,我們來看看如何使用異步搜索功能,工作中尤其是進行關聯(lián)數(shù)據(jù)的時候其用途更是大大的,方便性嘛,看看就知道了,好用的不得了。

基本的使用方法就不多說了,請看官們移步上文,我們這里繼續(xù)接著大侃大論。

我們先來預覽下異步搜索的效果圖

查看圖片

注意哦,圖中標記的部分是我們通過輸入的關鍵詞搜索出來的,異步這效果呢,我截圖上來估計你也看不到效果,動圖我還不會,不知道怎么搞的,要說具體是啥效果嗎,相信大多數(shù)人也是明白滴,這就叫做只可意會,言談不出來。好了,我們干脆直接上代碼看具體操作吧。

// view層
use kartikselect2Select2;
use yiiwebJsExpression;

<?php
  echo $form->field($model, 'title')->widget(Select2::classname(), [
    'options' => ['placeholder' => '請輸入標題名稱 ...'],
    'pluginOptions' => [
      'placeholder' => 'search ...',
      'allowClear' => true,
      'language' => [
        'errorLoading' => new JsExpression("function () { return 'Waiting...'; }"),
      ],
      'ajax' => [
        'url' => '這里是提供數(shù)據(jù)源的接口',
        'dataType' => 'json',
        'data' => new JsExpression('function(params) { return {q:params.term}; }')
      ],
      'escapeMarkup' => new JsExpression('function (markup) { return markup; }'),
      'templateResult' => new JsExpression('function(res) { return res.text; }'),
      'templateSelection' => new JsExpression('function (res) { return res.text; }'),
    ],
  ]);
?>

上面的代碼可直接復制使用,唯獨需要修改的就是ajax里對應的url地址。下面我們看看controller層代碼是怎么提供數(shù)據(jù)的。

//controller層
public function actionSearchTitle ($q)
{
  Yii::$app->response->format = yiiwebResponse::FORMAT_JSON;
  $out = ['results' => ['id' => '', 'text' => '']];
  if (!$q) {
    return $out;
  }

  $data = Article::find()
        ->select('id, title as text')
        ->andFilterWhere(['like', 'title', $q])
        ->limit(50)
        ->asArray()
        ->all();
        
  $out['results'] = array_values($data);

  return $out;
}

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持綠夏網(wǎng)。



主站蜘蛛池模板: 77316电影| 红日歌词完整版| river flows in you钢琴谱| 最佳女婿 电影| 杨超越穿游泳服装| 扎西顿珠的个人资料简介| 我的幸运猫 电视剧| 江苏体育频道直播| 来生缘吉他谱c调| 折叠画| 白宝山末路1997电视剧免费版| 康熙王朝是哪一年拍的| 男孩变女孩tg动画| 局外人电影| 美国电影golddiggers| 欧美喜剧电影| 电视剧火流星演员表| 拾贝的小女孩阅读理解答案 | 意大利火环1990| 音乐僵尸演员表| 明日战记| 伊人1314| 青春正步走 电视剧| ms培养基配方表| 陈程玉| 莱诺| 薄冰电视剧| 丰满视频| 被侵犯| 铠甲勇士第一部演员表| 南方车站的聚会| xmx| 美网直播| 爱情天梯| 来自地狱| fate动漫| 被五六个女同学掏蛋| 尹馨演过的三部电影| 变形金刚6免费观看高清完整版| 捆绑vk视频| 王渝萱全部电影|

!!!站長長期在線接!!!

網(wǎng)站、小程序:定制開發(fā)/二次開發(fā)/仿制開發(fā)等

各種疑難雜癥解決/定制接口/定制采集等

站長微信:lxwl520520

站長QQ:1737366103