• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com专业计算机教程网站
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • html/xhtml
  • html5
  • CSS
  • XML/XSLT
  • Dreamweaver教程
  • Frontpage教程
  • 心得技巧
  • bootstrap
  • vue
  • AngularJS
  • HBuilder教程
  • css3
  • 浏览器兼容
  • div/css
  • 网页编辑器
  • axure
您的位置:首页 > 网页设计 >vue > Javascript vue.js表格分页,ajax异步加载数据

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

作者: 字体:[增加 减小] 来源:互联网 时间:2017-05-30

本文主要包含vue.js ajax,vue.js ajax请求,vue.js使用ajax,javascript ajax,javascript ajax请求等相关知识,希望在学习及工作中可以帮助到您

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

效果:

代码:

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;
      }
    }
  });
</div>

模板:

<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>
</div>

HTML:

<div id='item_list'>
  ...
  <pagination :cur="1" :all="pageAll" :page-num="10" @page-to="loadList"></pagination>
</div>
</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();



</div>

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

</div>

您可能想查找下面的文章:

  • 使用vue框架 Ajax获取数据列表并用BootStrap显示出来
  • Vue form 表单提交+ajax异步请求+分页效果
  • Vue.js展示AJAX数据简单示例讲解
  • vue实现ajax滚动下拉加载,同时具有loading效果(推荐)
  • Javascript vue.js表格分页,ajax异步加载数据
  • Vue.js Ajax动态参数与列表显示实现方法
  • vue.js 表格分页ajax 异步加载数据

相关文章

  • 2017-05-30基于vue2.0+vuex的日期选择组件功能实现
  • 2017-05-30使用vue.js制作分页组件
  • 2017-05-30vue.js入门教程之计算属性
  • 2017-05-30Vue.js第一天学习笔记(数据的双向绑定、常用指令)
  • 2017-08-14Vue路由History mode模式中页面无法渲染的原因及解决
  • 2017-05-30vue2.0实现导航菜单切换效果
  • 2017-05-30Vue获取DOM元素样式和样式更改示例
  • 2017-05-30从0开始学Vue
  • 2017-05-30前端框架Vue.js中Directive知识详解
  • 2017-05-30vue2实现移动端上传、预览、压缩图片解决拍照旋转问题

文章分类

  • html/xhtml
  • html5
  • CSS
  • XML/XSLT
  • Dreamweaver教程
  • Frontpage教程
  • 心得技巧
  • bootstrap
  • vue
  • AngularJS
  • HBuilder教程
  • css3
  • 浏览器兼容
  • div/css
  • 网页编辑器
  • axure

最近更新的内容

    • Vue.js实现一个漂亮、灵活、可复用的提示组件示例
    • vue实现简单实时汇率计算功能
    • vue插件tab选项卡使用小结
    • Vue自定义指令拖拽功能示例
    • 强大Vue.js组件浅析
    • vue.js入门教程之绑定class和style样式
    • Vue2实现组件props双向绑定
    • 用v-html解决Vue.js渲染中html标签不被解析的问题
    • vue调用高德地图实例代码
    • vue实现动态数据绑定

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有