Angular2自定義分頁組件
在項目中,前端傳給后臺的參數(shù)有:
pageSize:每頁的條數(shù)
pageNo:當(dāng)前頁碼
比如當(dāng)前是第1頁,每頁20條,則后臺返回第1頁的20條記錄(sql應(yīng)該是用limit去獲取分頁數(shù)據(jù))
同時,后臺接口還會返回列表的總條數(shù)totalNum,前端根據(jù)totaNum/pageSize計算總共有多少頁
如圖:

注意事項:
需要先配置好路由(Angular2路由與導(dǎo)航)
使用步驟:
(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
<!--分頁組件參數(shù):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參數(shù)
public totalNum = 0; // 總數(shù)據(jù)條數(shù)
public pageSize = 20;// 每頁數(shù)據(jù)條數(shù)
public totalPage = 0;// 總頁數(shù)
public curPage = 1;// 當(dāng)前頁碼
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('當(dāng)前頁面', vm.curPage);
}
} else {
vm.params = {};
}
}
getPageData(pageNo) {
let vm = this;
vm.curPage = pageNo;
console.log('觸發(fā)', 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;// 子組件向父組件廣播事件,觸發(fā)改變當(dāng)前頁面的事件
public pageList = [1, 2, 3, 4, 5];
public totalPage = 5;
constructor() {
let vm = this;
//console.log('從父組件獲取的參數(shù)', vm['pageParams']);
}
getPageList(pageParams) {
/*分頁設(shè)置*/
let pageList=[];
if (pageParams.totalPage <= 5) {//如果總的頁碼數(shù)小于5(前五頁),那么直接放進數(shù)組里顯示
for (let i = 0; i < pageParams.totalPage; i++) {
pageList.push({
pageNo: i + 1
});
}
} else if (pageParams.totalPage - pageParams.curPage < 5 && pageParams.curPage > 4) {//如果總的頁碼數(shù)減去當(dāng)前頁碼數(shù)小于5(到達最后5頁),那么直接計算出來顯示
pageList = [
{
pageNo: pageParams.curPage - 4
}, {
pageNo: pageParams.curPage - 3
}, {
pageNo: pageParams.curPage - 2
}, {
pageNo: pageParams.curPage - 1
}, {
pageNo: pageParams.curPage
}
];
} else {//在中間的頁碼數(shù)
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.jb51.net/201704/yuanma/ng2-paginator-master_jb51.rar
以上就是本文的全部內(nèi)容,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作能帶來一定的幫助,同時也希望多多支持腳本之家!
相關(guān)文章
Angular 4根據(jù)組件名稱動態(tài)創(chuàng)建出組件的方法教程
組件是我們在學(xué)習(xí)angular中必不可少的一部分,下面這篇文章主要給大家介紹了關(guān)于Angular 4如何根據(jù)組件名稱動態(tài)創(chuàng)建出組件的相關(guān)資料,文中通過圖文與示例代碼介紹的非常詳細,需要的朋友可以參考借鑒,下面來一起看看吧。2017-11-11
AngularJs的UI組件ui-Bootstrap之Tooltip和Popover
這篇文章主要介紹了AngularJs的UI組件ui-Bootstrap之Tooltip和Popover,tooltip和popover是輕量的、可擴展的、用于提示的指令。具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-07-07
Angular2+國際化方案(ngx-translate)的示例代碼
本篇文章主要介紹了Angular2+國際化方案(ngx-translate)的示例代碼,具有一定的參考價值,有興趣的可以了解一下2017-08-08
詳解AngularJS controller調(diào)用factory
本篇文章主要介紹了詳解AngularJS controller調(diào)用factory,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-05-05
解決angular雙向綁定無效果,ng-model不能正常顯示的問題
今天小編就為大家分享一篇解決angular雙向綁定無效果,ng-model不能正常顯示的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-10-10
Angularjs 手寫日歷的實現(xiàn)代碼(不用插件)
本篇文章介紹了Angularjs 手寫日歷的實現(xiàn)代碼(不用插件),整理了詳細的代碼,非常具有實用價值,需要的朋友可以參考下2017-10-10
AngularJS控制器之間的數(shù)據(jù)共享及通信詳解
本文詳細介紹了AngularJS控制器之間的數(shù)據(jù)共享與通信,對angularjs共享數(shù)據(jù)及通信相關(guān)知識感興趣的朋友可以一起學(xué)習(xí)。2016-08-08

