在项目中,前端传给后台的参数有:

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
<!--分页组件参数:pageSize,totalNum,curPage,totalPage-->
<page-template [pageParams]="{pageSize:20,totalNum:100,curPage:1,totalPage:5}" (changeCurPage)="getPageData($event)"></page-template>
// 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
<!--分页组件-->
<div class="col-md-12 text-right margin-bottom" *ngIf="pageParams.totalPage>1 && pageParams.totalNum>0">
<a class="pull-left text-sm">总计 {{pageParams.totalNum}} 条,第 {{pageParams.curPage}} / {{pageParams.totalPage}} 页</a>
<button class="btn btn-default previous" [routerLink]="['./']" [disabled]="pageParams.curPage<=5"
(click)="changePage(pageParams.curPage-5)" [queryParams]="{pageNo:pageParams.curPage-5}"><<</button>
<button class="btn btn-default next" [routerLink]="['./']" (click)="changePage(pageParams.curPage-1)"
[queryParams]="{pageNo:pageParams.curPage-1}" [disabled]="pageParams.curPage==1">上一页</button>
<button class="btn btn-default" [routerLink]="['./']" [disabled]="pageParams.curPage==page.pageNo"
(click)="changePage(page.pageNo)" [queryParams]="page" *ngFor="let page of getPageList(pageParams)">
{{page.pageNo}}
</button>
<button class="btn btn-default next" [routerLink]="['./']" (click)="changePage(pageParams.curPage-(-1))"
[queryParams]="{pageNo:pageParams.curPage-(-1)}" [disabled]="pageParams.curPage==pageParams.totalPage">下一页</button>
<button class="btn btn-default previous" [routerLink]="['./']" [disabled]="pageParams.totalPage-pageParams.curPage<=5"
(click)="changePage(pageParams.curPage-(-5))" [queryParams]="{pageNo:pageParams.curPage-(-5)}">>></button>
</div>
<div class="col-md-12 text-center text-sm text-dark-gray" *ngIf="!pageParams.totalNum">
空空如也
</div>
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<Number> = 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);
}
}
ng2还在入门中,组件有待完善,请多多指教
项目demo:https://github.com/youzouzou/ng2-paginator
源码下载:http://xiazai./201704/yuanma/ng2-paginator-master_jb51.rar
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持!
# angular2
# 分页组件
# angularjs
# Angular2 组件交互实例详解
# Angular2学习教程之组件中的DOM操作详解
# angular2倒计时组件使用详解
# Angular2利用组件与指令实现图片轮播组件
# Angular2入门教程之模块和组件详解
# Angular2 父子组件数据通信实例
# 详解Angular2组件之间如何通信
# Angular2 组件间通过@Input @Output通讯示例
# Angular2 组件通信的实例代码
# 浅谈angular2 组件的生命周期钩子
# Angular2实现组件交互的方法分析
# 分页
# 每页
# 条数
# 还在
# 下一页
# 上一页
# 还会
# 有多少
# 空空如也
# 如图
# 请多多
# 源码下载
# 门中
# 应该是
# 前五
# 组里
# Demo
# declarations
# component
# Page
相关文章:
C#怎么创建控制台应用 C# Console App项目创建方法
linux top下的 minerd 木马清除方法
手机怎么制作网站教程步骤,手机怎么做自己的网页链接?
韩国网站服务器搭建指南:VPS选购、域名解析与DNS配置推荐
如何通过虚拟主机空间快速建站?
高性价比服务器租赁——企业级配置与24小时运维服务
建站之星如何快速更换网站模板?
如何快速打造个性化非模板自助建站?
免费制作海报的网站,哪位做平面的朋友告诉我用什么软件做海报比较好?ps还是cd还是ai这几个软件我都会些我是做网页的?
建站之星安装失败:服务器环境不兼容?
如何快速建站并高效导出源代码?
建站之星如何配置系统实现高效建站?
外贸公司网站制作哪家好,maersk船公司官网?
如何制作新型网站程序文件,新型止水鱼鳞网要拆除吗?
公司门户网站制作流程,华为官网怎么做?
正规网站制作公司有哪些,目前国内哪家网页网站制作设计公司比较专业靠谱?口碑好?
电商网站制作公司有哪些,1688网是什么意思?
小视频制作网站有哪些,有什么看国内小视频的网站,求推荐?
零基础网站服务器架设实战:轻量应用与域名解析配置指南
制作网站的模板软件,网站怎么建设?
建设网站制作价格,怎样建立自己的公司网站?
深圳企业网站制作设计,在深圳如何网上全流程注册公司?
C++如何编写函数模板?(泛型编程入门)
手机网站制作平台,手机靓号代理商怎么制作属于自己的手机靓号网站?
建站主机选购指南:核心配置与性价比推荐解析
如何选择网络建站服务器?高效建站必看指南
如何配置IIS站点权限与局域网访问?
公司网站的制作公司,企业网站制作基本流程有哪些?
教学论文网站制作软件有哪些,写论文用什么软件
?
网站微信制作软件,如何制作微信链接?
相册网站制作软件,图片上的网址怎么复制?
如何在万网ECS上快速搭建专属网站?
重庆网站制作公司哪家好,重庆中考招生办官方网站?
免费制作小说封面的网站有哪些,怎么接网站批量的封面单?
如何实现建站之星域名转发设置?
免费网站制作模板下载,除了易企秀之外还有什么H5平台可以制作H5长页面,最好是免费的?
如何快速搭建虚拟主机网站?新手必看指南
网站制作服务平台,有什么网站可以发布本地服务信息?
猪八戒网站制作视频,开发一个猪八戒网站,大约需要多少?或者自己请程序员,需要什么程序员,多少程序员能完成?
如何选择高效稳定的ISP建站解决方案?
如何通过FTP空间快速搭建安全高效网站?
如何选择适配移动端的WAP自助建站平台?
制作网站的公司有哪些,做一个公司网站要多少钱?
如何零基础开发自助建站系统?完整教程解析
建站主机功能解析:服务器选择与快速搭建指南
建站之星备案是否影响网站上线时间?
建站之星五站合一营销型网站搭建攻略,流量入口全覆盖优化指南
Java解压缩zip - 解压缩多个文件或文件夹实例
网站制作多少钱一个,建一个论坛网站大约需要多少钱?
宝盒自助建站智能生成技巧:SEO优化与关键词设置指南
*请认真填写需求信息,我们会在24小时内与您取得联系。