美文网首页YII2.0
Yii2时间区间筛选扩展-DateRangePicker

Yii2时间区间筛选扩展-DateRangePicker

作者: 落花轻舞问君愁 | 来源:发表于2017-06-14 11:04 被阅读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), '<');//结束时间
    }
    

    相关文章

      网友评论

        本文标题:Yii2时间区间筛选扩展-DateRangePicker

        本文链接:https://www.haomeiwen.com/subject/jpjsqxtx.html