国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

Javascript vue.js表格分頁,ajax異步加載數據

2019-11-20 08:40:56
字體:
來源:轉載
供稿:網友

分頁一般和表格一起用,分頁鏈接作為表格的一部分,將分頁鏈接封裝成一個獨立的組件,然后作為子組件嵌入到表格組件中,這樣比較合理。

效果:

代碼:

1.注冊一個組件

js

Vue.component('pagination',{    template:'#paginationTpl',    replace:true,    props:['cur','all','pageNum'],    methods:{      //頁碼點擊事件      btnClick: function(index){        if(index != this.cur){          this.cur = index;        }      }    },    watch:{      "cur" : function(val,oldVal) {        this.$dispatch('page-to', val);      }    },    computed:{      indexes : function(){        var list = [];        //計算左右頁碼        var mid = parseInt(this.pageNum / 2);//中間值        var left = Math.max(this.cur - mid,1);        var right = Math.max(this.cur + this.pageNum - mid -1,this.pageNum);        if (right > this.all ) { right = this.all}        while (left <= right){          list.push(left);          left ++;        }        return list;      },      showLast: function(){        return this.cur != this.all;      },      showFirst: function(){        return this.cur != 1;      }    }  });

模板:

<script type="text/template" id="paginationTpl">  <nav v-if="all > 1">    <ul class="pagination">      <li v-if="showFirst"><a href="javascript:" @click="cur--">«</a></li>      <li v-for="index in indexes" :class="{ 'active': cur == index}">        <a @click="btnClick(index)" href="javascript:">{{ index }}</a>      </li>      <li v-if="showLast"><a @click="cur++" href="javascript:">»</a></li>      <li><a>共<i>{{all}}</i>頁</a></li>    </ul>  </nav></script>

HTML:

<div id='item_list'>  ...  <pagination :cur="1" :all="pageAll" :page-num="10" @page-to="loadList"></pagination></div>

當點擊分頁鏈接的時候,通過watch cur,子組件分發 page-to 事件,通過 @page-to="loadList" 標簽指定使用父組件 loadList 方法處理事件,父組件接收到page值然后ajax加載數據,根據服務端返回計算并更新自身的 pageAll 值,因為子組件prop通過 :all="pageAll" 動態綁定了父組件的pageAll對象,所以子組件會聯動更新。

附上一個簡單的表格組件例子:

var vm = new Vue({    el: "#item_list",    data: {      items : [],      //分頁參數      pageAll:0, //總頁數,根據服務端返回total值計算      perPage:10 //每頁數量    },    methods: {      loadList:function(page){        var that = this;        $.ajax({          url : "/getList",          type:"post",          data:{"page":page,"perPage":this.perPage},          dataType:"json",          error:function(){alert('請求列表失敗')},          success:function(res){            if (res.status == 1) {              that.items = res.data.list;              that.perPage = res.data.perPage;              that.pageAll = Math.ceil(res.data.total / that.perPage);//計算總頁數            }          }        });      },      //初始化      init:function(){        this.loadList(1);      }    }  });  vm.init();

感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 雅江县| 永嘉县| 彭泽县| 博爱县| 威海市| 通许县| 南城县| 台南市| 桦南县| 崇州市| 苏尼特右旗| 辽阳县| 双城市| 宜良县| 巴楚县| 伽师县| 广宁县| 鄂托克旗| 锡林浩特市| 福州市| 苗栗县| 道孚县| 田林县| 黔南| 博野县| 宜春市| 余江县| 比如县| 赤水市| 界首市| 祥云县| 区。| 清涧县| 独山县| 灌云县| 澜沧| 同仁县| 宝坻区| 土默特左旗| 内黄县| 若尔盖县|