编程开源技术交流,分享技术与知识

网站首页 > 开源技术 正文

分享:Yii2 Gridview时间区间筛选插件-DateRangePicker

wxchong 2024-09-11 10:49:43 开源技术 6 ℃ 0 评论
实现效果

实现步骤
  • 首先使用composer申明依赖DateRangePicker

composer require "kartik-v/yii2-date-range": "*"
  • 申明依赖后打开你的视图文件,在头部引入DateRangePicker命名空间

use kartik\daterange\DateRangePicker;
  • 我们只需要在视图文件里GridView的columns找到你要进行日期筛选的那一列,案例里是repaymentTime这一列,在这一列里添加filter参数,参数的值为小部件DateRangePicker

这里要注意的是DateRangePicker小部件里的name和value根据你当前model来进行修改,否则model是接收不到你的请求的参数然后时间格式使用format参数进行设置 ,如果format设置了时间格式一定要convertFormat=>true,不然会有问题。separator是间隔符号,例如 separator当前的值为/ 最后显示的时间区间就是 2016-10-17/2016-10-31[ 'attribute' => 'repaymentTime', 'format' => ['date', "php:Y-m-d H:i:s"], 'headerOptions' => ['width' => '12%'], 'filter' => DateRangePicker::widget([ 'name' => 'BorrowRepaymentSearch[repaymentTime]', 'value' => Yii::$app->request->get('BorrowRepaymentSearch')['repaymentTime'], 'convertFormat' => true, 'pluginOptions' => [ 'locale' => [ 'format' => 'Y-m-d', 'separator' => '/', ] ] ])]
  • 后台处理 只需要通过间隔符/来进行分割repaymentTime这个字段的值,并且将其转换成unix时间戳即可

if (!empty($this->repaymentTime)) { $query->andFilterCompare('repaymentTime', strtotime(explode('/', $this->repaymentTime)[0]), '>=');//起始时间 $query->andFilterCompare('repaymentTime', (strtotime(explode('/', $this->repaymentTime)[1]) + 86400), '<');//结束时间}

Tags:

本文暂时没有评论,来添加一个吧(●'◡'●)

欢迎 发表评论:

最近发表
标签列表