欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Angular2自定義分頁(yè)組件

 更新時(shí)間:2017年04月19日 09:27:56   作者:Mr_Sparta  
本篇文章主要介紹了Angular2自定義分頁(yè)組件的相關(guān)知識(shí)。具有很好的參考價(jià)值。下面跟著小編一起來(lái)看下吧

在項(xiàng)目中,前端傳給后臺(tái)的參數(shù)有:

pageSize:每頁(yè)的條數(shù)

pageNo:當(dāng)前頁(yè)碼

比如當(dāng)前是第1頁(yè),每頁(yè)20條,則后臺(tái)返回第1頁(yè)的20條記錄(sql應(yīng)該是用limit去獲取分頁(yè)數(shù)據(jù))

同時(shí),后臺(tái)接口還會(huì)返回列表的總條數(shù)totalNum,前端根據(jù)totaNum/pageSize計(jì)算總共有多少頁(yè)

如圖:

注意事項(xiàng):

需要先配置好路由(Angular2路由與導(dǎo)航

使用步驟:

(1)在項(xiàng)目中引入分頁(yè)組件

// 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)在頁(yè)面中使用分頁(yè)組件:

// demo.html
<!--分頁(yè)組件參數(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; // 保存頁(yè)面url參數(shù)
 public totalNum = 0; // 總數(shù)據(jù)條數(shù)
 public pageSize = 20;// 每頁(yè)數(shù)據(jù)條數(shù)
 public totalPage = 0;// 總頁(yè)數(shù)
 public curPage = 1;// 當(dāng)前頁(yè)碼
 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)前頁(yè)面', vm.curPage);
   }
  } else {
   vm.params = {};
  }
 }
 getPageData(pageNo) {
  let vm = this;
  vm.curPage = pageNo;
  console.log('觸發(fā)', pageNo);
 }
}

分頁(yè)組件源碼:

page.html

<!--分頁(yè)組件-->
<div class="col-md-12 text-right margin-bottom" *ngIf="pageParams.totalPage>1 && pageParams.totalNum>0">
 <a class="pull-left text-sm">總計(jì) {{pageParams.totalNum}} 條,第 {{pageParams.curPage}} / {{pageParams.totalPage}} 頁(yè)</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">上一頁(yè)</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">下一頁(yè)</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)前頁(yè)面的事件

 public pageList = [1, 2, 3, 4, 5];
 public totalPage = 5;

 constructor() {
  let vm = this;
  //console.log('從父組件獲取的參數(shù)', vm['pageParams']);

 }

 getPageList(pageParams) {
  /*分頁(yè)設(shè)置*/
  let pageList=[];
  if (pageParams.totalPage <= 5) {//如果總的頁(yè)碼數(shù)小于5(前五頁(yè)),那么直接放進(jìn)數(shù)組里顯示
   for (let i = 0; i < pageParams.totalPage; i++) {
    pageList.push({
     pageNo: i + 1
    });
   }
  } else if (pageParams.totalPage - pageParams.curPage < 5 && pageParams.curPage > 4) {//如果總的頁(yè)碼數(shù)減去當(dāng)前頁(yè)碼數(shù)小于5(到達(dá)最后5頁(yè)),那么直接計(jì)算出來(lái)顯示
   pageList = [
    {
     pageNo: pageParams.curPage - 4
    }, {
     pageNo: pageParams.curPage - 3
    }, {
     pageNo: pageParams.curPage - 2
    }, {
     pageNo: pageParams.curPage - 1
    }, {
     pageNo: pageParams.curPage
    }
   ];
  } else {//在中間的頁(yè)碼數(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('修改頁(yè)碼', pageNo);
  vm.pageParams.curPage = pageNo;
  vm.changeCurPage.emit(vm.pageParams.curPage);
 }
}

ng2還在入門中,組件有待完善,請(qǐng)多多指教

項(xiàng)目demo:https://github.com/youzouzou/ng2-paginator

源碼下載:http://xiazai.jb51.net/201704/yuanma/ng2-paginator-master_jb51.rar

以上就是本文的全部?jī)?nèi)容,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作能帶來(lái)一定的幫助,同時(shí)也希望多多支持腳本之家!

相關(guān)文章

  • Angular 4根據(jù)組件名稱動(dòng)態(tài)創(chuàng)建出組件的方法教程

    Angular 4根據(jù)組件名稱動(dòng)態(tài)創(chuàng)建出組件的方法教程

    組件是我們?cè)趯W(xué)習(xí)angular中必不可少的一部分,下面這篇文章主要給大家介紹了關(guān)于Angular 4如何根據(jù)組件名稱動(dòng)態(tài)創(chuàng)建出組件的相關(guān)資料,文中通過(guò)圖文與示例代碼介紹的非常詳細(xì),需要的朋友可以參考借鑒,下面來(lái)一起看看吧。
    2017-11-11
  • AngularJS實(shí)現(xiàn)標(biāo)簽頁(yè)的兩種方式

    AngularJS實(shí)現(xiàn)標(biāo)簽頁(yè)的兩種方式

    這篇文章分別給大家介紹了AngularJS實(shí)現(xiàn)標(biāo)簽頁(yè)的兩種方式,一種是通過(guò)普通指令實(shí)現(xiàn)標(biāo)簽頁(yè),另外一種是通過(guò)自定義指令實(shí)現(xiàn)的標(biāo)簽頁(yè),有需要的朋友們可以來(lái)參考借鑒,下面來(lái)一起看看吧。
    2016-09-09
  • AngularJs的UI組件ui-Bootstrap之Tooltip和Popover

    AngularJs的UI組件ui-Bootstrap之Tooltip和Popover

    這篇文章主要介紹了AngularJs的UI組件ui-Bootstrap之Tooltip和Popover,tooltip和popover是輕量的、可擴(kuò)展的、用于提示的指令。具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-07-07
  • Angular2+國(guó)際化方案(ngx-translate)的示例代碼

    Angular2+國(guó)際化方案(ngx-translate)的示例代碼

    本篇文章主要介紹了Angular2+國(guó)際化方案(ngx-translate)的示例代碼,具有一定的參考價(jià)值,有興趣的可以了解一下
    2017-08-08
  • 詳解AngularJS controller調(diào)用factory

    詳解AngularJS controller調(diào)用factory

    本篇文章主要介紹了詳解AngularJS controller調(diào)用factory,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-05-05
  • angular.element方法匯總

    angular.element方法匯總

    本文主要給大家匯總了一下angular.element的方法,十分的詳細(xì),這里推薦給大家 參考下。
    2015-01-01
  • AngularJS初始化靜態(tài)模板詳解

    AngularJS初始化靜態(tài)模板詳解

    這篇文章主要為大家介紹了AngularJS初始化靜態(tài)模板,AngularJS初始化靜態(tài)模板有兩種方式,一是通過(guò)ng-app來(lái)自動(dòng)初始化模塊,也可以通過(guò)angular.bootstrap(document, [module])手動(dòng)啟動(dòng)應(yīng)用,感興趣的小伙伴們可以參考一下
    2016-01-01
  • 解決angular雙向綁定無(wú)效果,ng-model不能正常顯示的問(wèn)題

    解決angular雙向綁定無(wú)效果,ng-model不能正常顯示的問(wèn)題

    今天小編就為大家分享一篇解決angular雙向綁定無(wú)效果,ng-model不能正常顯示的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2018-10-10
  • Angularjs 手寫(xiě)日歷的實(shí)現(xiàn)代碼(不用插件)

    Angularjs 手寫(xiě)日歷的實(shí)現(xiàn)代碼(不用插件)

    本篇文章介紹了Angularjs 手寫(xiě)日歷的實(shí)現(xiàn)代碼(不用插件),整理了詳細(xì)的代碼,非常具有實(shí)用價(jià)值,需要的朋友可以參考下
    2017-10-10
  • AngularJS控制器之間的數(shù)據(jù)共享及通信詳解

    AngularJS控制器之間的數(shù)據(jù)共享及通信詳解

    本文詳細(xì)介紹了AngularJS控制器之間的數(shù)據(jù)共享與通信,對(duì)angularjs共享數(shù)據(jù)及通信相關(guān)知識(shí)感興趣的朋友可以一起學(xué)習(xí)。
    2016-08-08

最新評(píng)論