Heim  >  Artikel  >  Backend-Entwicklung  >  Ausführliche Erläuterung von Beispielen der Zeitperiodenfilterfunktion in der YII-Rasteransicht

Ausführliche Erläuterung von Beispielen der Zeitperiodenfilterfunktion in der YII-Rasteransicht

小云云
小云云Original
2018-01-26 13:34:161609Durchsuche

yii Gridview ist leistungsstark, aber die Zeitfilterung ist problematisch, was mit dem Speicherformat der Datenbank zusammenhängt. Das Zeitformat dieses Artikels ist der Datumstyp. In diesem Artikel wird hauptsächlich die Zeitperiodenfilterfunktion von yii Gridview ausführlich vorgestellt. Ein Eingabefeld und die automatische Übermittlung haben einen gewissen Referenzwert. Ich hoffe, es kann jedem helfen.

Dann kommt das Problem, yii bietet nur ein Textsuchformat über die Zeit, das heißt, es kann nur genaue Daten wie 2017-8-10 finden. Der Kunde von Almighty sagte, das würde nicht funktionieren, ich möchte nach einem Zeitraum suchen! Ich möchte nur ein Eingabefeld! Ich möchte automatisch einreichen!

Zu beachtende Punkte:

Führen Sie zunächst relevante js in die Rasteransicht ein, um doppelte Datumsangaben zu implementieren. js, einfach und großzügig (Nachteile: Sie können das Jahr nicht auswählen, Sie müssen manuell klicken, ich werde die Jahre hier nicht groß aufspannen, es ist verfügbar)

Um die Daten im Suchmodell zu verarbeiten, Zeitabfrage durchführen

3. Fallstrick: Nach der Auswahl des Datums hat das Eingabefeld keinen Cursor und Sie müssen zweimal klicken und dann die Eingabetaste drücken, um die Daten zu aktualisieren, was sich deutlich von der ursprünglichen Gridview-Erfahrung unterscheidet

4. Leiter: Wenn die eingegebenen Datumsdaten erkannt werden. Verwenden Sie abschließend jq, um die Aktion zum Senden von Wagenrückläufen zu simulieren, wodurch das ursprüngliche Erlebnis ähnlich wie bei Gridview perfekt umgesetzt wird, seidenweiche

Ansicht


<?php

//use yii\web\View;
use kartik\grid\GridView;
use yii\bootstrap\Html;
use common\helps\ArrayHelper;
use yii\helpers\Url;

//引入时间段js,这里使用了jquery.daterangepicker.js
$this->registerCssFile(&#39;/plugins/datep/css/daterangepicker.css&#39;);
$this->registerJsFile(&#39;/plugins/datep/js/moment.min.js&#39;);
$this->registerJsFile(&#39;/plugins/datep/js/jquery.daterangepicker.js&#39;);
$this->registerJsFile(&#39;/plugins/datep/js/demo.js&#39;);
?>

<body class="gray-bg">
  <p class="wrapper wrapper-content animated fadeInRight">
    <p class="row">
      <p class="col-sm-12">
        <p class="ibox float-e-margins">
           <?= backend\widgets\TitleBack::widget([&#39;title&#39;=>&#39;记录管理&#39;]) ?>
           
          <p class="ibox-content">  
            
          <?php
                   
            echo GridView::widget([
                &#39;dataProvider&#39; => $dataProvider,
                &#39;filterModel&#39; => $searchModel,
     
                &#39;columns&#39; => [
                  
                  [&#39;class&#39; => &#39;yii\grid\SerialColumn&#39;],
                  [&#39;class&#39; => &#39;yii\grid\CheckboxColumn&#39;],
                  &#39;title&#39;,
                  
                  [
                    
                        &#39;label&#39;=>&#39;下发时间&#39;,
                        &#39;attribute&#39;=>&#39;issued&#39;,
                     &#39;value&#39; => function ($data) {
                      return ArrayHelper::get_date_time($data->issued);
                    },                    
                  ],
                ]
             ]);
          
          ?>
            </p>
            </p>
          </p>
        </p>
      </p>

    </p>
  </p>
</body>

demo .js wird am Ende eingefügt. Lassen Sie uns zunächst über PatentDataBdSearch sprechen. Es verarbeitet die aus dem Eingabefeld gesendeten Daten und fragt die Datenbank während des Zeitraums

ab


//时间段筛选
    if($this->issued){
      $time= explode(&#39;~&#39;, $this->issued);
      $query->andFilterWhere([&#39;between&#39;, &#39;patent_data.issued&#39;, $time[0],$time[1]]); 
    }

demo.js zur Implementierung der Datenerkennung und -simulation


$(function(){
  
  /*
  define a new language named "custom"  插件设置
  */

  $.dateRangePickerLanguages[&#39;custom&#39;] = 
  {
    &#39;selected&#39;: &#39;Choosed:&#39;,
    &#39;days&#39;: &#39;Days&#39;,
    &#39;apply&#39;: &#39;Close&#39;,
    &#39;week-1&#39; : &#39;Mon&#39;,
    &#39;week-2&#39; : &#39;Tue&#39;,
    &#39;week-3&#39; : &#39;Wed&#39;,
    &#39;week-4&#39; : &#39;Thu&#39;,
    &#39;week-5&#39; : &#39;Fri&#39;,
    &#39;week-6&#39; : &#39;Sat&#39;,
    &#39;week-7&#39; : &#39;Sun&#39;,
    &#39;month-name&#39;: [&#39;January&#39;,&#39;February&#39;,&#39;March&#39;,&#39;April&#39;,&#39;May&#39;,&#39;June&#39;,&#39;July&#39;,&#39;August&#39;,&#39;September&#39;,&#39;October&#39;,&#39;November&#39;,&#39;December&#39;],
    &#39;shortcuts&#39; : &#39;Shortcuts&#39;,
    &#39;past&#39;: &#39;Past&#39;,
    &#39;7days&#39; : &#39;7days&#39;,
    &#39;14days&#39; : &#39;14days&#39;,
    &#39;30days&#39; : &#39;30days&#39;,
    &#39;previous&#39; : &#39;Previous&#39;,
    &#39;prev-week&#39; : &#39;Week&#39;,
    &#39;prev-month&#39; : &#39;Month&#39;,
    &#39;prev-quarter&#39; : &#39;Quarter&#39;,
    &#39;prev-year&#39; : &#39;Year&#39;,
    &#39;less-than&#39; : &#39;Date range should longer than %d days&#39;,
    &#39;more-than&#39; : &#39;Date range should less than %d days&#39;,
    &#39;default-more&#39; : &#39;Please select a date range longer than %d days&#39;,
    &#39;default-less&#39; : &#39;Please select a date range less than %d days&#39;,
    &#39;default-range&#39; : &#39;Please select a date range between %d and %d days&#39;,
    &#39;default-default&#39;: &#39;This is costom language&#39;
  };
  
  
  //下面设置称自己的输入框选择器
  $("input[name=&#39;PatentDataBdSearch[issued]&#39;]").dateRangePicker(
  {
     //时间段的类型设置,这里是输入框时间段以~分隔,选择时间后自动消失弹出框
     separator : &#39; ~ &#39;,
     autoClose: true
  }).bind(&#39;datepicker-change&#39;,function(e,r)
  {
    try
    {
      console.log(r);
            //重要:如果检测有输入值了,就在输入框显示光标,或者模拟回车事件,自动提交,像gridview原生功能
              //不添加下面的代码,将无法自动提交,
            var issued=$("input[name=&#39;PatentDataBdSearch[issued]&#39;]").val();
            console.log(issued);
            if(issued){
              //输入之后显示光标
              //$("input[name=&#39;PatentDataBdSearch[issued]&#39;]").focus();
                //模拟回车操作,输入后自动提交,刷新数据,一定要设置时间计数器,否则将无法提交

              setTimeout(function(){
                e = jQuery.Event("keydown");
                e.keyCode = 13; //enter key
                jQuery("input[name=&#39;PatentDataBdSearch[issued]&#39;]").trigger(e);

              },100);
            }
    }catch(e){}
  });
});

Verwandte Empfehlungen; >

js setinterval-Methode zum Ändern des Laufzeitzeitraums

Javascript implementiert die Methode zum Anzeigen von Begrüßungen entsprechend dem Zeitraum

Javascript implementiert den Code zur Bestimmung des Zeitraums

Das obige ist der detaillierte Inhalt vonAusführliche Erläuterung von Beispielen der Zeitperiodenfilterfunktion in der YII-Rasteransicht. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn