这篇文章主要介绍了Angular2如何自定义分页组件,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。
西湖ssl适用于网站、小程序/APP、API接口等需要进行数据传输应用场景,ssl证书未来市场广阔!成为创新互联建站的ssl证书销售渠道,可以享受市场价格4-6折优惠!如果有意向欢迎电话联系或者加微信:18980820575(备注:SSL证书合作)期待与您的合作!
在项目中,前端传给后台的参数有:
pageSize:每页的条数
pageNo:当前页码
比如当前是第1页,每页20条,则后台返回第1页的20条记录(sql应该是用limit去获取分页数据)
同时,后台接口还会返回列表的总条数totalNum,前端根据totaNum/pageSize计算总共有多少页
如图:
注意事项:
需要先配置好路由(Angular2路由与导航)
使用步骤:
(1)在项目中引入分页组件
// app.module.ts import { BrowserModule } from '@angular/platform-browser'; import { NgModule } from '@angular/core'; import { FormsModule } from '@angular/forms'; import { HttpModule } from '@angular/http'; import { AppComponent } from './app.component'; import { RouterModule } from '@angular/router'; import { Demo } from './demo/demo'; import { Page } from './page/page'; @NgModule({ declarations: [ AppComponent, Demo, Page ], imports: [ BrowserModule, FormsModule, RouterModule.forRoot([ { path: 'demo', component: Demo } ]), HttpModule ], providers: [], bootstrap: [AppComponent] }) export class AppModule { }
(2)在页面中使用分页组件:
// demo.html// demo.ts import { Component } from '@angular/core'; import { Location } from '@angular/common'; import { Router } from '@angular/router'; @Component({ selector: 'demo', templateUrl: './demo.html' }) export class Demo { public params; // 保存页面url参数 public totalNum = 0; // 总数据条数 public pageSize = 20;// 每页数据条数 public totalPage = 0;// 总页数 public curPage = 1;// 当前页码 constructor(location:Location) { let vm = this; if (vm.params) { vm.params = vm.params.replace('?', '').split('&'); let theRequest = []; for (let i = 0; i < vm.params.length; i++) { theRequest[vm.params[i].split("=")[0]] = vm.params[i].split("=")[0] == 'pageNo' ? parseInt(vm.params[i].split("=")[1]) : vm.params[i].split("=")[1]; } vm.params = theRequest; if (vm.params['pageNo']) { vm.curPage = vm.params['pageNo']; //console.log('当前页面', vm.curPage); } } else { vm.params = {}; } } getPageData(pageNo) { let vm = this; vm.curPage = pageNo; console.log('触发', pageNo); } }
分页组件源码:
page.html
1 && pageParams.totalNum>0"> 总计 {{pageParams.totalNum}} 条,第 {{pageParams.curPage}} / {{pageParams.totalPage}} 页空空如也
page.ts
import { Component,Input, Output,EventEmitter } from '@angular/core'; @Component({ selector: 'page', templateUrl: './page.html' }) export class Page { @Input('pageParams') pageParams;// 父组件向子组件传值 @Output() changeCurPage:EventEmitter= new EventEmitter;// 子组件向父组件广播事件,触发改变当前页面的事件 public pageList = [1, 2, 3, 4, 5]; public totalPage = 5; constructor() { let vm = this; //console.log('从父组件获取的参数', vm['pageParams']); } getPageList(pageParams) { /*分页设置*/ let pageList=[]; if (pageParams.totalPage <= 5) {//如果总的页码数小于5(前五页),那么直接放进数组里显示 for (let i = 0; i < pageParams.totalPage; i++) { pageList.push({ pageNo: i + 1 }); } } else if (pageParams.totalPage - pageParams.curPage < 5 && pageParams.curPage > 4) {//如果总的页码数减去当前页码数小于5(到达最后5页),那么直接计算出来显示 pageList = [ { pageNo: pageParams.curPage - 4 }, { pageNo: pageParams.curPage - 3 }, { pageNo: pageParams.curPage - 2 }, { pageNo: pageParams.curPage - 1 }, { pageNo: pageParams.curPage } ]; } else {//在中间的页码数 let cur = Math.floor((pageParams.curPage - 1) / 5) * 5 + 1; pageList = [ { pageNo: cur }, { pageNo: cur + 1 }, { pageNo: cur + 2 }, { pageNo: cur + 3 }, { pageNo: cur + 4 }, ]; } return pageList; } changePage(pageNo) { let vm = this; //console.log('修改页码', pageNo); vm.pageParams.curPage = pageNo; vm.changeCurPage.emit(vm.pageParams.curPage); } }
感谢你能够认真阅读完这篇文章,希望小编分享的“Angular2如何自定义分页组件”这篇文章对大家有帮助,同时也希望大家多多支持创新互联,关注创新互联行业资讯频道,更多相关知识等着你来学习!