2017-02-11 8 views
0

私は自分のプロジェクトの1つにVuejsとdataTableを使用しています。私はAjaxコールを作成し、データを配列にプッシュします。その後、私は<tr>タグ内のデータをループするためにv-forを使用します。ほとんどの場合、動作しません。ページのロードが終了するとすぐにテーブルがロードされます.AJAXデータを受け取るのに少し時間がかかります。ここに出力があります。 enter image description hereVuejs AjaxコールとdataTable

したがって、serchオプションは正しく機能しません。私は少し時間の後にテーブルを読み込むsetTimeout関数(それは悪い考えだった)を使用すると思った。それを行う適切な方法は何でしょうか?ブレードで

new Vue({ 
       el: '#app', 
       data: { 
        entries: [], 
       }, 
       methods:{ 
        getData(){ 
         var route = '/admin/temporary-enrolled-students'; 
         this.$http.get(route).then((response)=>{ 
          for(var i = 0; i< response.data.length;i++) 
          { 
           this.entries.push({ 
            scId: response.data[i].id, 
            name: response.data[i].user.name, 
            phone: response.data[i].user.phone, 
            email: response.data[i].user.email, 
            courseId: response.data[i].course.id, 
            courseName: response.data[i].course.course_title, 
            expiryDate: response.data[i].expiry_date, 
            shares: response.data[i].number_of_shares, 
            expired: (response.data[i].expired == 1), 
            enrollDate: response.data[i].created_at 
           }) 
          } 

         }) 
        }, 
       }, 
       mounted(){ 
        this.getData(); 
       }, 
      }); 
//data table 
$(function() { 
      setTimeout(()=> {   
       $("#temp-enroll").DataTable({ 
        "paging": true, 
        "ordering": false, 
        "info": true, 
        "autoWidth": false 
       }); 
      },1000); 
     }); 

:コードを共有すること

答えて

1

[OK]私はこれを試して、私が望んだものを正確に動作させました。皆さん、お世話になりました。

new Vue({ 
       el: '#app', 
       data: { 
        entries: [], 
       }, 
       methods:{ 
        getData(){ 
         var route = '/admin/temporary-enrolled-students'; 
         this.$http.get(route).then((response)=>{ 
          for(var i = 0; i< response.data.length;i++) 
          { 
           this.entries.push({ 
            scId: response.data[i].id, 
            name: response.data[i].user.name, 
            ............................ 
            ...................... 
            enrollDate: response.data[i].created_at 
           }) 
          } 

         }).then(()=>{ 
          $("#temp-enroll").DataTable({ 
          "paging": true, 
          "ordering": false, 
          "info": true, 
          "autoWidth": false 
          }); 
          }); 
        }, 
       }, 
       mounted(){ 
        this.getData(); 
       }, 
      }); 
+1

'$ http'場所に来たのか不思議に思っている人のために注意! 'vue-resource'を使ってください。ここでガイドを参照することができます:https://github.com/pagekit/vue-resource – Syed

0

あなたは、プロパティhttps://vuejs.org/v2/guide/computed.html#Watchersを見てみてください。 doc:

ほとんどの場合、計算されたプロパティがより適切ですが、 は、カスタムウォッチャーが必要なときです。そのため、Vueは に、ウォッチオプションを通じてデータ変更に対応するためのより一般的な方法を提供しています。 これは、データの変更に応じて非同期または高価な オペレーションを実行する場合に最も便利です。

0

私は誰かが計算されたプロパティが行く方法だと言いました、と私は同様にお勧めします。

あなたのテンプレートが計算されたプロパティへの参照を作成するとすぐに、これがあなたのajax呼び出しをトリガーする理由です。ページは他の使用可能な要素をレンダリングし、Ajax呼び出しが返ってきたら、受け取ったデータをレンダリングします。コードに特別な操作は必要ありません。

とにかく、ここで返された成功の約束で戻り一例として...

<table> 
     <tr v-for="item in serverData"> 
      <td>{{item.name}}</td> 
      <td>{{item.someOtherValue}}</td> 
     </tr> 
    </table> 

export default { 
    name: 'pets', 
    data() { 
    return { 
    } 
    }, 
    computed: { 
    serverData: function() { 
     // ajax call using axios - returns a json array [] 
     axios.get("http://localhost:8080/getSomeData") 
     .success(function(data) { 
      return data; 
     }; 
    } 
} 

}

お知らせ、それはあなたのHTML内...

のようになります。 ajax呼び出しからデータを別の変数に格納する必要はありません(また、上記のnoobコーダーの例のようにループする必要はありません)。サーバ上でそれを行い、レンダリングの準備ができた配列を返します。あなたのウェブサービスではありません。元のデータを操作してください)。

計算された値を参照するテンプレートの部分は、データが到着した後にレンダリングされます。それを見る必要はありません。

希望すると便利です。

Vueは爆弾です!

0
<template> 
    <div class="panel panel-default tablecontainer"> 
     <div class="panel-heading">ChartBookin Import</div> 
     <br> 
     <div class='col-md-12'> 
      <div class='col-md-3'></div> 
      <div class='col-md-3'> 
       <div class="panel panel-default"> 

        <div class="panel-body"> 
         <commitChart :width="150" 
            :height="150"></commitChart> 
        </div> 

       </div> 
      </div> 

      <div class='col-md-3'> 
       <div class="panel panel-default"> 

        <div class="panel-body"> 
         <InboxMessage :width="150" 
            :height="150"></InboxMessage> 
        </div> 

       </div> 
      </div> 
     </div> 
     <div class="panel-body"> 
      <div class='col-md-3'> 
       <label> by Account </label> 
       <select v-model="teamId" class="form-control" rows="3"> 
        <option VALUE="" disabled> CHOISIR UN TEAM</option> 
        <option v-for="option in options" v-bind:value="option.id">{{option.name}}</option> 
       </select> 
      </div> 
      <div class='col-md-3'> 
       <label> by Date</label> 
       <div class="form-group"> 

        <input type="text" class="form-control" name="daterange" 
          value="01/01/2017-01/31/2017"/> 
       </div> 
      </div> 
      <div class='col-md-5'></div> 
      <div class='col-md-1'> 
       <label>Records</label> 
       <div class="form-group"> 

        <select v-model="elementsPerPage" class="form-control"> 

         <option v-for="option in filtre" v-bind:value="option"> 
          {{ option }} 
         </option> 
        </select> 
       </div> 
      </div> 

      <div id="sixthTable"> 

       <table class="table-bordered table-striped table-bordered table-hover"> 
        <thead> 
        <tr> 

         <th v-for=" (key,value) in rows[0]" v-on:click="sortTable(value)">{{value}} 
          <div class="arrow" v-if="value == sortColumn" 
           v-bind:class="[ascending ? 'arrow_up' : 'arrow_down']"></div> 
         </th> 
         <th>Actions</th> 
        </tr> 
        </thead> 
        <tbody> 

        <tr v-if=" rows.length > 0" v-for="row in rows"> 
         <td v-for="(key, value) in row">{{ key }}</td> 
         <td> 
          <a :href="'/stat_booking_import/' + row.Id"> 
           <span class="glyphicon glyphicon-eye-open"></span> 
          </a> 

         </td> 
        </tr> 
        <tr v-else> No Result Founded</tr> 
        </tbody> 

       </table> 
       <div class="pagination"> 


        <div id="paginatebutton"> 
         <a href="#">&laquo;</a> 
         <a class="" v-for="i in num_pages()" 
          v-bind:class="[i == currentPage ? 'active' : '']" 
          v-on:click="change_page(i)">{{i}} 
         </a> 
         <a href="#">&raquo;</a> 
        </div> 

        <div class="col-md-12" id="paginatetexte"> 
         <p v-if="pages > (elementsPerPage*currentPage) "> 
          Showing 1 to {{elementsPerPage * currentPage }} of {{ pages }} records 
         </p> 
         <p v-else> 
          Showing 1 to {{pages}} of {{ pages }} records 
         </p> 
        </div> 

       </div> 
      </div> 

     </div> 
    </div> 


</template> 


<script> 
    import Vue from 'vue'; 
    import axios from 'axios'; 
    import CommitChart from './Mail'; 
    import InboxMessage from './Inbox'; 


    export default { 
     components: { 
      CommitChart, 
      InboxMessage 

     }, 
     data() { 
      return { 
       filtre: [10, 25, 50, 100], 
       option: 0, 
       options: [], 
       currentPage: 1, 
       elementsPerPage: 10, 
       pages: 0, 
       ascending: false, 
       sortColumn: '', 
       startdate: null, 
       enddate: null, 
       options: [], 
       teamId: null, 
       columns: [], 
       messages: [], 
       date: 0, 
       rows: {}, 
      } 
     }, 

     created() { 
      this.getData(); 
      this.getTeams(); 
      this.getMailInbox(); 

     }, 
     mounted() { 
      let vm = this; 
      $(document).ready(function() { 
       $('input[name="daterange"]').daterangepicker({ 
        ranges: { 
         'Today': [moment(), moment()], 
         'Yesterday': [moment().subtract(1, 'days'), moment().subtract(1, 'days')], 
         'Last 7 Days': [moment().subtract(6, 'days'), moment()], 
         'This Month': [moment().startOf('month'), moment().endOf('month')] 
        }, 
        locale: { 
         format: 'YYYY-MM-DD' 
        }, 
       }); 

       $('.applyBtn').click(function() { 
        vm.startdate = $("input[name=daterangepicker_start]").val(); 
        vm.enddate = $("input[name=daterangepicker_end]").val(); 
        vm.getData(); 


       }); 
       $('input[name="daterange"]').on('apply.daterangepicker', function (ev, picker) { 
        vm.startdate = $("input[name=daterangepicker_start]").val(); 
        vm.enddate = $("input[name=daterangepicker_end]").val(); 
        vm.getData(); 
       }); 

      }); 
     }, 
     watch: { 
      date: function() { 
       this.getData(); 
      }, 
      teamId: function() { 
       this.getData(); 
      }, 
      elementsPerPage: function() { 
       this.getData(); 
      } 


     }, 
     methods: { 

      getData() { 

       axios.get(`/admin/stat_booking_import.json/` + this.startdate + `/` + this.teamId + `/` + this.enddate + `/` + this.elementsPerPage + `?page=` + this.currentPage) 
        .then(response => { 
         this.rows = response.data.elements.data; 
         this.columns = Object.keys(this.rows[0]); 
         this.pages = response.data.elements.total_element; 
        }) 
        .catch(e => { 
         this.errors.push(e) 
        }) 

      }, 
      getTeams() { 
       axios.get('/admin/team.json') 
        .then(response => { 
         this.options = response.data.data; 
         this.errors = []; 

        }) 
        .catch(e => { 
         e.message = "aucun resultat trouvé essayer de choisir une autre date"; 
         this.errors.push(e) 
        }) 
      }, 
      getMailInbox() { 
       axios.get(`/mailstorage.json`) 
        .then(response => { 
         this.messages = response.data.data; 
         console.log(this.messages); 

        }) 
        .catch(e => { 
         this.errors.push(e) 
        }); 
      }, 

      sortTable(col) { 
       if (this.sortColumn === col) { 
        this.ascending = !this.ascending; 
       } else { 
        this.ascending = true; 
        this.sortColumn = col; 
       } 

       var ascending = this.ascending; 

       this.rows.sort(function (a, b) { 
        if (a[col] > b[col]) { 
         return ascending ? 1 : -1 
        } else if (a[col] < b[col]) { 
         return ascending ? -1 : 1 
        } 
        return 0; 
       }) 
      }, 
      num_pages() { 

       return Math.ceil(this.pages/this.elementsPerPage); 
      }, 
      get_rows() { 
       var start = (this.currentPage - 1) * this.elementsPerPage; 
       var end = start + this.elementsPerPage; 
       return this.rows.slice(start, end); 
      }, 
      change_page(page) { 
       this.currentPage = page; 
       this.getData(); 
      } 
     }, 

    } 


</script> 
<style type="text/css"> 
    table { 
     width: 100%; 
    } 

    table td { 
     text-align: center; 
    } 

    table td { 
     text-align: center; 
     padding: 8px; 

    } 

    table td:last-child { 
     border-right: none; 
    } 

    .pagination { 
     display: inline-block; 
    } 

    .pagination a { 
     color: #3097D1; 
     float: left; 
     padding: 8px 16px; 
     text-decoration: none; 
     transition: background-color .3s; 
     border: 1px solid #ddd; 
    } 

    .pagination a.active { 
     background-color: #3097D1; 
     color: white; 
     border: 1px solid #3097D1; 
    } 

    .arrow_down { 
     background-image: url('') 
    } 

    .arrow_up { 
     background-image: url('') 
    } 

    .arrow { 
     float: right; 
     width: 12px; 
     height: 15px; 
     background-repeat: no-repeat; 
     background-size: contain; 
     background-position-y: bottom; 
    } 

    .number { 
     display: inline-block; 
     padding: 4px 10px; 
     margin: 0px 5px; 
     cursor: pointer; 

    } 

    .number:hover, 
    .number.active { 
     background-color: #3097D1; 
     border-color: #3097D1; 
    } 

    #paginatetexte { 
     padding-top: 6%; 

import Vue from 'vue' 
 

 

 
new Vue({ 
 
    el: '#statistique', 
 
    render: h => h(require('./StatBookingImport.vue')) 
 
});
<style type="text/css"> 
 
    table { 
 
     width: 100%; 
 
    } 
 

 
    table td { 
 
     text-align: center; 
 
    } 
 

 
    table td { 
 
     text-align: center; 
 
     padding: 8px; 
 

 
    } 
 

 
    table td:last-child { 
 
     border-right: none; 
 
    } 
 

 
    .pagination { 
 
     display: inline-block; 
 
    } 
 

 
    .pagination a { 
 
     color: #3097D1; 
 
     float: left; 
 
     padding: 8px 16px; 
 
     text-decoration: none; 
 
     transition: background-color .3s; 
 
     border: 1px solid #ddd; 
 
    } 
 

 
    .pagination a.active { 
 
     background-color: #3097D1; 
 
     color: white; 
 
     border: 1px solid #3097D1; 
 
    } 
 

 
    .arrow_down { 
 
     background-image: url('') 
 
    } 
 

 
    .arrow_up { 
 
     background-image: url('') 
 
    } 
 

 
    .arrow { 
 
     float: right; 
 
     width: 12px; 
 
     height: 15px; 
 
     background-repeat: no-repeat; 
 
     background-size: contain; 
 
     background-position-y: bottom; 
 
    } 
 

 
    .number { 
 
     display: inline-block; 
 
     padding: 4px 10px; 
 
     margin: 0px 5px; 
 
     cursor: pointer; 
 

 
    } 
 

 
    .number:hover, 
 
    .number.active { 
 
     background-color: #3097D1; 
 
     border-color: #3097D1; 
 
    } 
 

 
    #paginatetexte { 
 
     padding-top: 6%; 
 
    } 
 

 
    #paginatebutton { 
 
     border-radius: 1px; 
 
    } 
 

 
    .tablecontainer { 
 

 
     margin-right: 2%; 
 
     margin-left: 2%; 
 
    } 
 

 
    .mailinbox { 
 
     margin-left: 1%; 
 
    } 
 

 
</style>
<template> 
 
    <div class="panel panel-default tablecontainer"> 
 
     <div class="panel-heading">ChartBookin Import</div> 
 
     <br> 
 
     <div class='col-md-12'> 
 
      <div class='col-md-3'></div> 
 
      <div class='col-md-3'> 
 
       <div class="panel panel-default"> 
 

 
        <div class="panel-body"> 
 
         <commitChart :width="150" 
 
            :height="150"></commitChart> 
 
        </div> 
 

 
       </div> 
 
      </div> 
 

 
      <div class='col-md-3'> 
 
       <div class="panel panel-default"> 
 

 
        <div class="panel-body"> 
 
         <InboxMessage :width="150" 
 
            :height="150"></InboxMessage> 
 
        </div> 
 

 
       </div> 
 
      </div> 
 
     </div> 
 
     <div class="panel-body"> 
 
      <div class='col-md-3'> 
 
       <label> by Account </label> 
 
       <select v-model="teamId" class="form-control" rows="3"> 
 
        <option VALUE="" disabled> CHOISIR UN TEAM</option> 
 
        <option v-for="option in options" v-bind:value="option.id">{{option.name}}</option> 
 
       </select> 
 
      </div> 
 
      <div class='col-md-3'> 
 
       <label> by Date</label> 
 
       <div class="form-group"> 
 

 
        <input type="text" class="form-control" name="daterange" 
 
          value="01/01/2017-01/31/2017"/> 
 
       </div> 
 
      </div> 
 
      <div class='col-md-5'></div> 
 
      <div class='col-md-1'> 
 
       <label>Records</label> 
 
       <div class="form-group"> 
 

 
        <select v-model="elementsPerPage" class="form-control"> 
 

 
         <option v-for="option in filtre" v-bind:value="option"> 
 
          {{ option }} 
 
         </option> 
 
        </select> 
 
       </div> 
 
      </div> 
 

 
      <div id="sixthTable"> 
 

 
       <table class="table-bordered table-striped table-bordered table-hover"> 
 
        <thead> 
 
        <tr> 
 

 
         <th v-for=" (key,value) in rows[0]" v-on:click="sortTable(value)">{{value}} 
 
          <div class="arrow" v-if="value == sortColumn" 
 
           v-bind:class="[ascending ? 'arrow_up' : 'arrow_down']"></div> 
 
         </th> 
 
         <th>Actions</th> 
 
        </tr> 
 
        </thead> 
 
        <tbody> 
 

 
        <tr v-if=" rows.length > 0" v-for="row in rows"> 
 
         <td v-for="(key, value) in row">{{ key }}</td> 
 
         <td> 
 
          <a :href="'/stat_booking_import/' + row.Id"> 
 
           <span class="glyphicon glyphicon-eye-open"></span> 
 
          </a> 
 

 
         </td> 
 
        </tr> 
 
        <tr v-else> No Result Founded</tr> 
 
        </tbody> 
 

 
       </table> 
 
       <div class="pagination"> 
 

 

 
        <div id="paginatebutton"> 
 
         <a href="#">&laquo;</a> 
 
         <a class="" v-for="i in num_pages()" 
 
          v-bind:class="[i == currentPage ? 'active' : '']" 
 
          v-on:click="change_page(i)">{{i}} 
 
         </a> 
 
         <a href="#">&raquo;</a> 
 
        </div> 
 

 
        <div class="col-md-12" id="paginatetexte"> 
 
         <p v-if="pages > (elementsPerPage*currentPage) "> 
 
          Showing 1 to {{elementsPerPage * currentPage }} of {{ pages }} records 
 
         </p> 
 
         <p v-else> 
 
          Showing 1 to {{pages}} of {{ pages }} records 
 
         </p> 
 
        </div> 
 

 
       </div> 
 
      </div> 
 

 
     </div> 
 
    </div> 
 

 

 
</template> 
 

 

 
<script> 
 
    import Vue from 'vue'; 
 
    import axios from 'axios'; 
 
    import CommitChart from './Mail'; 
 
    import InboxMessage from './Inbox'; 
 

 

 
    export default { 
 
     components: { 
 
      CommitChart, 
 
      InboxMessage 
 

 
     }, 
 
     data() { 
 
      return { 
 
       filtre: [10, 25, 50, 100], 
 
       option: 0, 
 
       options: [], 
 
       currentPage: 1, 
 
       elementsPerPage: 10, 
 
       pages: 0, 
 
       ascending: false, 
 
       sortColumn: '', 
 
       startdate: null, 
 
       enddate: null, 
 
       options: [], 
 
       teamId: null, 
 
       columns: [], 
 
       messages: [], 
 
       date: 0, 
 
       rows: {}, 
 
      } 
 
     }, 
 

 
     created() { 
 
      this.getData(); 
 
      this.getTeams(); 
 
      this.getMailInbox(); 
 

 
     }, 
 
     mounted() { 
 
      let vm = this; 
 
      $(document).ready(function() { 
 
       $('input[name="daterange"]').daterangepicker({ 
 
        ranges: { 
 
         'Today': [moment(), moment()], 
 
         'Yesterday': [moment().subtract(1, 'days'), moment().subtract(1, 'days')], 
 
         'Last 7 Days': [moment().subtract(6, 'days'), moment()], 
 
         'This Month': [moment().startOf('month'), moment().endOf('month')] 
 
        }, 
 
        locale: { 
 
         format: 'YYYY-MM-DD' 
 
        }, 
 
       }); 
 

 
       $('.applyBtn').click(function() { 
 
        vm.startdate = $("input[name=daterangepicker_start]").val(); 
 
        vm.enddate = $("input[name=daterangepicker_end]").val(); 
 
        vm.getData(); 
 

 

 
       }); 
 
       $('input[name="daterange"]').on('apply.daterangepicker', function (ev, picker) { 
 
        vm.startdate = $("input[name=daterangepicker_start]").val(); 
 
        vm.enddate = $("input[name=daterangepicker_end]").val(); 
 
        vm.getData(); 
 
       }); 
 

 
      }); 
 
     }, 
 
     watch: { 
 
      date: function() { 
 
       this.getData(); 
 
      }, 
 
      teamId: function() { 
 
       this.getData(); 
 
      }, 
 
      elementsPerPage: function() { 
 
       this.getData(); 
 
      } 
 

 

 
     }, 
 
     methods: { 
 

 
      getData() { 
 

 
       axios.get(`/admin/stat_booking_import.json/` + this.startdate + `/` + this.teamId + `/` + this.enddate + `/` + this.elementsPerPage + `?page=` + this.currentPage) 
 
        .then(response => { 
 
         this.rows = response.data.elements.data; 
 
         this.columns = Object.keys(this.rows[0]); 
 
         this.pages = response.data.elements.total_element; 
 
        }) 
 
        .catch(e => { 
 
         this.errors.push(e) 
 
        }) 
 

 
      }, 
 
      getTeams() { 
 
       axios.get('/admin/team.json') 
 
        .then(response => { 
 
         this.options = response.data.data; 
 
         this.errors = []; 
 

 
        }) 
 
        .catch(e => { 
 
         e.message = "aucun resultat trouvé essayer de choisir une autre date"; 
 
         this.errors.push(e) 
 
        }) 
 
      }, 
 
      getMailInbox() { 
 
       axios.get(`/mailstorage.json`) 
 
        .then(response => { 
 
         this.messages = response.data.data; 
 
         console.log(this.messages); 
 

 
        }) 
 
        .catch(e => { 
 
         this.errors.push(e) 
 
        }); 
 
      }, 
 

 
      sortTable(col) { 
 
       if (this.sortColumn === col) { 
 
        this.ascending = !this.ascending; 
 
       } else { 
 
        this.ascending = true; 
 
        this.sortColumn = col; 
 
       } 
 

 
       var ascending = this.ascending; 
 

 
       this.rows.sort(function (a, b) { 
 
        if (a[col] > b[col]) { 
 
         return ascending ? 1 : -1 
 
        } else if (a[col] < b[col]) { 
 
         return ascending ? -1 : 1 
 
        } 
 
        return 0; 
 
       }) 
 
      }, 
 
      num_pages() { 
 

 
       return Math.ceil(this.pages/this.elementsPerPage); 
 
      }, 
 
      get_rows() { 
 
       var start = (this.currentPage - 1) * this.elementsPerPage; 
 
       var end = start + this.elementsPerPage; 
 
       return this.rows.slice(start, end); 
 
      }, 
 
      change_page(page) { 
 
       this.currentPage = page; 
 
       this.getData(); 
 
      } 
 
     }, 
 

 
    } 
 

 

 
</script>

} 

    #paginatebutton { 
     border-radius: 1px; 
    } 

    .tablecontainer { 

     margin-right: 2%; 
     margin-left: 2%; 
    } 

    .mailinbox { 
     margin-left: 1%; 
    } 

</style> 
関連する問題