vue.js表格分页,ajax异步加载数据

原创
2016/10/17 16:25
阅读数 9.2K

分页一般和表格一起用,分页链接作为表格的一部分,将分页链接封装成一个独立的组件,然后作为子组件嵌入到表格组件中,这样比较合理。

效果:

输入图片说明

代码:

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--">&laquo;</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:">&raquo;</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();
展开阅读全文
打赏
7
166 收藏
分享
加载中
你应该考虑用尤大大写的插件来批量加分号https://github.com/yyx990803/semi
2017/01/26 13:02
回复
举报
吾爱博主

引用来自“top8843”的评论

计算总页数,确定是Math.round(),而不是Math.ceil() ?
总数除以每页条数,不管余数是几,都应该向上取整,而不是四舍五入,如果每页10条,不管是单1条,还是单9条,都应该算一页.
多谢指正
2016/10/23 19:23
回复
举报
计算总页数,确定是Math.round(),而不是Math.ceil() ?
总数除以每页条数,不管余数是几,都应该向上取整,而不是四舍五入,如果每页10条,不管是单1条,还是单9条,都应该算一页.
2016/10/23 19:21
回复
举报
计算总页数,确定是Math.round(),而不是Math.ceil() ?
2016/10/23 19:09
回复
举报
这没条件过滤,哈哈
2016/10/19 09:58
回复
举报
真的呢
2016/10/19 07:43
回复
举报
js分页一般怎么写的,还有jquery插件吗
2016/10/18 19:45
回复
举报

引用来自“极乐网”的评论

请问博主,可以转载么?会注明来源和作者的~

引用来自“吾爱”的评论

可以 ,支持分享
谢谢博主~
2016/10/18 14:44
回复
举报
吾爱博主

引用来自“极乐网”的评论

请问博主,可以转载么?会注明来源和作者的~
可以 ,支持分享
2016/10/18 14:43
回复
举报
请问博主,可以转载么?会注明来源和作者的~
2016/10/18 14:29
回复
举报
更多评论
打赏
14 评论
166 收藏
7
分享
返回顶部
顶部