私が yii フレームワークに触れてから約 2 か月が経ちますが、yii フレームワークについての理解はそれほど深くなく、体系的に勉強したことがなく、作業中にいくつかの問題に遭遇しました。知識を理解している場合にのみマニュアルをお読みください。
前のプロジェクトでは、関連付けられたテーブルのフィールドを表示し、検索とソート機能を持たせる必要がありましたが、これまでに出会ったことがなかったので、マニュアルで関連する情報を探してこの要件を書き出しました。それが利用可能になったとき、Daoyun はいくつかのメモを取り、今日はたまたま週末だったので、私はそれをブログにまとめる時間がありました。
早速、手順に進みましょう。
背景: ここでは、GII によって自動的に生成された CURL に関連するテーブル フィールドを追加します。
要件: テーブル B に関連付けられたテーブル A にフィールド pt_id があり、テーブル A の GII によって生成された CURL に基づいて、検索および並べ替え関数を使用してテーブル B に関連付けられたフィールドの名前の値を追加する必要があります。 。
1 //意思即获取Pt的数据 2 public function getPt() //get** get后面任意 3 { 4 //模型名:className(),B表字段=>A表对应字段 5 return $this->hasOne(Pt::className(), ['id' => 'ptid']); 6 }
1 public $name; //可以关联显示多个字段 2 public $*****; //例子
1 //search函数中添加 表示在SQL语句中增加关联查询 2 //看起来是那么的熟悉,哈哈 3 $query->joinWith(['pt']); //这里等待pt中的值就是step1中get后面的命名
1 //这里存放的是可以排序的字段 2 //如果A Search已经存在setSort,则其他动,只需要添加新的字段就可以了 3 //但是,我的yii 2生成的Search不存在这个排序,因此就需要额外添加了 4 //注意:当你的search中不存在这个配置时,即表明默认配置里面有设置过,当你在这里添加一个setSort则将会覆盖默认配置,之前默认有排序功能的字段将会失效 5 $dataProvider->setSort( 6 'attributes'=>[ 7 //====添加新字段排序配置= 8 'name'=>[ 9 'asc'=>['name' => SORT_ASC], 10 'desc'=>['name' => SORT_DESC], 11 'lable'=>'name', 12 ], 13 //================== 14 ] 15 );
1 //在代码里面照着队形添加这一句即可 2 //like,关联表全名,this->name 3 $query->andFilterWhere(['like', '**_pt.name', $this->name]) ;
この時点で半分以上は完了していますが、このコントローラーにアクセスするとページの効果が表示されますが、検索すると機能しません。
今回提出した現場情報は安全ではないため、プログラムには記録されません。
1 'columns' => [ 2 //=========== 3 //添加 4 [ 5 'attribute' => 'name', 6 'label' => '平台', 7 'value' => 'pt.name', 8 'filter' => Html::activeTextInput($searchModel, 'name', [ 9 'class' => 'form-control' 10 ]), 11 ], 12 //============= 13 ]
仕事は完了です! !
これは単なる例です。この例を通じて、Yii に関連するフィールドを追加する方法を知ることができ、既存の知識に基づいてさらに多くのトリックを変更できます。 。 。 。
以上がYiiフレームワークにおける検索・ソート機能付き関連フィールドの実装例の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。