1. 程式人生 > >Yii2下拉框實現

Yii2下拉框實現

詳細介紹yii2下拉框的實現方法,以商品分類的下拉框為例:

第一種方法:使用Html的activeDropDownList(),該方法的優點是:可以自定義下拉框的樣式。具體實現如下:

1.控制器中,獲取檢視中所需的資料

    public function actionList(){
        $category_model=new Category();
        $category_info=$category_model->find()->all();
        return $this->renderPartial('list',['category_info'=>$category_info,'category_model'=>$category_model]);
    }

2.檢視中,use yii\helpers\Html;

<?php $form = ActiveForm::begin([]);?>
    <?php echo Html::activeDropDownList($category_model,'category_name',ArrayHelper::map($category_info,'category_id','category_name'),['style'=>'border:1px solid    gray;width:150px;'])?>           
<?php ActiveForm::end(); ?>

3.這樣之後,表單的下拉框名稱是:Category Name,如果要改變這個值,在控制器對應的模型中使用attributeLabels()方法,具體如下:

 

  public function attributeLabels(){
        return array(
            'category_name'=>'分類',
        );
    }

第二種方法:使用ActiveForm的dropDownList(),優點是使用的yii自定義的樣式,也可以自定義樣式

1.控制器中獲取檢視中需要的資料

2.檢視中,use yii\helpers\Html;
use yii\widgets\ActiveForm;
use yii\helpers\ArrayHelper;

<?php $form = ActiveForm::begin([]);?>
    <?php echo $form->field($category_model,'category_name')->dropDownList(ArrayHelper::map($category_info,'category_id','category_name'),['style'=>'border:1px solid blue;width:150px;'])?>           
<?php ActiveForm::end(); ?>

補充:該方法也可以自定義樣式:具體如上程式碼

注意:如果要在下拉框的首項新增‘請選擇’、‘全部’等預設的值。用prompt,程式碼如下:

 <?php echo $form->field($brand_model,'brand_name')->dropDownList(ArrayHelper::map($brand_info,'brand_id','brand_name'),['prompt'=>'全部'])?>  

各引數說明:

ArrayHelper::map()------------生成k=>v的一維或多維陣列

$category_info----------------後臺獲取的資料

category_id-------------------option的value值

category_name---------------select 的name值