Yii2时间区间筛选扩展-DateRangePicker

实现效果
实现步骤
  • 首先使用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), '<');//结束时间
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 136,282评论 19 139
  • ¥开启¥ 【iAPP实现进入界面执行逐一显】 〖2017-08-25 15:22:14〗 《//首先开一个线程,因...
    小菜c阅读 11,940评论 0 17
  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 33,783评论 18 399
  • 周日晚上的红蓝对决,曼联做客斯坦福桥净吞四弹,惨淡收场。上一次,穆里尼奥输的这么惨还是初入伯纳乌的时候,被巴萨5:...
    内寒阅读 1,756评论 0 0
  • 世界上唯一值得你努力争取的东西那便是爱
    Tolstoy赞阅读 1,355评论 0 0

友情链接更多精彩内容