Yii2.0小部件GridView(两表联查/搜索/分页)功能的实现代码
副问题[/!--empirenews.page--]
GridView 两表联查/搜刮/分页当我们在一个网格视图中表现勾当数据的时辰,你也许会碰着这种环境,就是表现关联表的列的值,为了使关联列可以或许排序,你必要毗连副黄?,以及添加排序法则到数据提供者的排序组件中,对数据举办搜刮,排序。 Ⅰ.节制器层Controller
*@version [version 1.0] [书本打点]
*/
class BooksInfoController extends Controller
{
//书本列表 Ⅱ.查询模子层Model
*@version [vector 1.0] [书本详情模子]
*/
class BooksInfo extends ActiveRecord
{
/**
* @配置表名
*/
public static function tableName()
{
return '{{%books_info}}';
}
//关联表
public function getBooksType(){
// hasOne要求返回两个参数 第一个参数是关联表的类名 第二个参数是两张表的关联相关
// 这里id是books_type表的id,关联books_info表的type_id
return $this->hasOne(BooksType::className(),['id' => 'type_id']);
}
public function attributeLabels()
{
return [
'id' => 'ID','book_name' => '书本名称','book_face' => '书本封面','type_id' => '书本分类ID','type_name' => '书本分类',];
}
}
?>
Ⅲ.搜刮模子层Search
*/
// 留意:此处担任的是查询Model--->BooksInfo
class InfoSearch extends BooksInfo
{
public $type_name; //界说属性变量
// 只有在 rules() 函数中声明的字段才可以搜刮
public function rules()
{
return [
// [['book_name','type_name'],'safe'],[['type_name'],];
}
public function scenarios()
{
// 旁路在父类中实现的 scenarios() 函数
return Model::scenarios();
}
public function search($params)
{
$query = BooksInfo::find();
$dataProvider = new ActiveDataProvider([
'query' => $query,'pagination' => [
'pageSize' => 1,],]);
/*这里的articlecategory是article模子内里关联的要领名,除了首字母,其他都要完全一样,不然会报错*/
$query->joinWith(['booksType']);
// 从参数的数据中加载过滤前提,并验证
if (!($this->load($params) && $this->validate())) {
return $dataProvider;
}
// 增进过滤前提来调解查询工具
$query->andFilterWhere(['like','book_name',$this->book_name]);
//添加关联字段过滤前提[留意:此处books_type.type_name中books_type为分类表名]
$query->andFilterWhere(['like','books_type.type_name',$this->type_name]);
return $dataProvider;
}
}
?>
Ⅳ.视图层Viewtitle = '图书列表'; ?> $data,//数据源 'filterModel' => $searchModel,//搜刮列 'columns' => [ // ['filterModel' => $searchModel],['class' => 'yiigridCheckboxColumn'],//复选框列 ['attribute' => 'id'],['attribute' => 'book_name',['attribute' => 'book_face','content'=>function($model){ // 图片表现 return Html::img($model->book_face,['width'=>'50']); }],[ 'attribute' => 'type_name','value' => 'booksType.type_name',//两表联查[书本范例] ],['class' => 'yiigridActionColumn','header'=>'操纵'],//举措列 ],'pager' => [//自界说分页样式以及表现内容 'prevPageLabel'=>'上一页','nextPageLabel'=>'下一页','firstPageLabel' => '第一页','lastPageLabel' => '最后一页','options'=>['style'=>'margin-left:200px;','class'=>"pagination"],]); ?>Ⅴ.结果展示总结(编辑:湖南网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |