首页 > 技术资料 > php相关 >

Yii2框架之ListView小部件的使用方法

金聪采编分享 2102

ListView是yii框架中类似GridView,也是用于展示多条数据的小部件,相比GridView,ListView可以更加灵活地设置数据展示的格式。

下面以我自己做的一个使用ListView来展示数据的例子,来简单讲解一下ListView小部件的使用。

首先需要在控制器中new一个数据提供器,传给视图,示例代码如下:

public function actionIndex() {  $dataProvider = new ActiveDataProvider([    'query' => Diary::find()->orderBy('day'),    'pagination' => [//分页      'pagesize' => 4    ]  ]);  return $this->render('index', [    'dataProvider' => $dataProvider  ]);}

接下来就是在视图文件中使用ListView来展示数据了,示例代码如下:

<?= ListView::widget([  'dataProvider' => $dataProvider,//数据提供器  'itemView' => '_diary',//指定item视图(该视图文件与当前视图在同一个目录下)  'viewParams' => [//传参数给每一个item    'moodCfg' => Mood::getAll()  ],  'layout' => '{items}<div class="col-lg-12 sum-pager">{summary}{pager}</div>',//整个ListView布局  'itemOptions' => [//针对渲染的单个item    'tag' => 'div',    'class' => 'col-lg-3'  ],  /*  'options' => [//针对整个ListView    'tag' => 'div',    'class' => 'col-lg-3'  ],  */  'pager' => [    //'options' => ['class' => 'hidden'],//关闭分页(默认开启)    /* 分页按钮设置 */    'maxButtonCount' => 5,//最多显示几个分页按钮    'firstPageLabel' => '首页',    'prevPageLabel' => '上一页',    'nextPageLabel' => '下一页',    'lastPageLabel' => '尾页'  ]]);?>

这里说明一下,由于ListView和GridView继承于同一个父类BaseListView,所以有很多设置参数是一样的,可以通过参考GridView的参数设置来设置ListView。

最后就是在ListView的'itemView'参数指定的视图文件中来编写每一条数据的展示格式了,示例代码如下:

<div class="item">  <h4 style="font-weight:bold"><?= Html::encode($model->title ? $model->title : '(无题)') ?></h4>     <p style="font-size:13px">    <span style="color:orangered"><?= date('Y.m.d', $model->day) ?></span><br>    <span style="color:#999">心情:<?= $moodCfg[$model->mood] ?></span>//这里访问ListView的'viewParams'参数传过来的参数$moodCfg  </p>     <div style="margin:15px 0">            <?php echo HtmlPurifier::process(mb_substr($model->content, 0, 25).'......'); ?>  </div>     <p class="info">    添加:<?= date('Y-m-d H:i:s', $model->created_at) ?><br>    最后修改:<?= date('Y-m-d H:i:s', $model->updated_at) ?>  </p>     <div style="text-align:right">    <?= Html::a('<span class="glyphicon glyphicon-eye-open"></span>', ['view', 'id' => $model->id], ['title' => '查看']) ?>    <?= Html::a('<span class="glyphicon glyphicon-pencil"></span>', ['upcreate', 'id' => $model->id], ['title' => '修改']) ?>    <?= Html::a('<span class="glyphicon glyphicon-trash"></span>', ['delete', 'id' => $model->id], [      'title' => '删除',      'data' => [        'confirm' => '您确定真的要删除 '.date('Y年m月d日', $model->day).' 的日记吗?',        'method' => 'post',      ]    ]) ?>  </div></div>

最后的最后,效果图展示时间(略丑,勿怪):

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持金聪精品

相关推荐

词霸天下38000词汇速记全集(完全版)

福利经验

教育培训机构30条朋友圈招生实用文案,赶快收藏

商业模式

凹凸社区APP源码蜜桃社区源码+视频搭建教程

管理系统

最新X站自动采集网站源码,久草影视系统源码PHP视频网站程序

管理系统

免费QQ在线查绑(旧公库)源码引流必备源码

管理系统

热门图文

上一篇:php curl请求接口并获取数据的示例代码

下一篇:php面向对象(一) 初窥(php面向对象基础介绍)