Angular4 後臺管理系統搭建(1) - 建立一個通用的Wijmo5 flexgrid分頁器組件

来源:http://www.cnblogs.com/Vetkdf/archive/2017/06/26/7080893.html
-Advertisement-
Play Games

17年4月,開始學習angular2,到5月跟著升級到angular4。目前還在學習,搭建中。我的最終目的是用angular4框架搭建一個後臺管理系統。這裡使用了三個關鍵的外部庫。 1、使用adminLte 皮膚。這個是bootstrap的一款皮膚。風格比較嚴肅。所以選這個皮膚; 2、引用了ngx- ...


17年4月,開始學習angular2,到5月跟著升級到angular4。目前還在學習,搭建中。我的最終目的是用angular4框架搭建一個後臺管理系統。這裡使用了三個關鍵的外部庫。

1、使用adminLte 皮膚。這個是bootstrap的一款皮膚。風格比較嚴肅。所以選這個皮膚;

2、引用了ngx-bootstrap。這個是bootstrap對應angular的庫;

3、使用wijmo5 flexgrid表格,號稱是angular下最好的表格組件。

 

本章說下如何搭建一個flexgrid通用分頁器組件,angular的核心就是組件化,所以在搭建組件上,天生就有長處。一般是在父類組件上添加flexgrid的表格,所有和分頁相關的信息,按鈕。整合進入分頁器組件內。所以我們先明確父類組件和分頁器組件之間需要傳遞的參數。

父類組件向分頁器組件傳遞兩個參數,當前頁面  pageindex 。頁碼總數  pagecount。在分頁器子類組件內,點擊跳轉按鈕。調用父類組件的輸定綁定函數,重新綁定表格即可。分頁器最終效果如下

demo 演示地址   http://114.215.44.2

github地址         https://github.com/Vetkdf/yang-test

 

分頁器組件ts代碼,關鍵就是兩個Input參數,一個Output監聽。

import { Component, OnInit, Input, Output, EventEmitter} from '@angular/core';

@Component({
  selector: 'app-paging',
  templateUrl: './paging.component.html',
  styleUrls: ['./paging.component.css']
})
export class PagingComponent implements OnInit {

  constructor() { }

  @Input() pageIndex: number = 1;
  @Input() pageCount: number = 1;
  @Output() change: EventEmitter<number> = new EventEmitter<number>();

  ngOnInit() {
  }

  moveToFirstPage() {
    this.change.emit(1);
  }

  moveToPreviousPage() {
    this.change.emit(this.pageIndex - 1);
  }

  moveToNextPage(){
    this.change.emit(this.pageIndex + 1);
  }

  moveToLastPage() {
    this.change.emit(this.pageCount);
  }

}

分頁器組件html代碼,四個按鈕跳轉最後,最前,上一頁,下一頁。按鈕要把消息傳遞給父類組件,觸發重綁定表格即可。

<div class="btn-group">
   <button type="button" class="btn btn-default"
       (click)="this.moveToFirstPage()"
       [disabled]="this.pageIndex <= 1">
       <span class="glyphicon glyphicon-fast-backward"></span>
   </button>
   <button type="button" class="btn btn-default"
       (click)="this.moveToPreviousPage()"
       [disabled]="this.pageIndex <= 1">
       <span class="glyphicon glyphicon-step-backward"></span>
   </button>
   <button type="button" class="btn btn-default" disabled style="width:100px">
        {{ this.pageIndex | number }} / {{ this.pageCount | number }}
   </button>
   <button type="button" class="btn btn-default"
       (click)="this.moveToNextPage()"
       [disabled]="this.pageIndex >= this.pageCount">
       <span class="glyphicon glyphicon-step-forward"></span>
   </button>
   <button type="button" class="btn btn-default"
       (click)="this.moveToLastPage()"
       [disabled]="this.pageIndex >= this.pageCount">
   <span class="glyphicon glyphicon-fast-forward"></span>
   </button>
</div>

父類調用代碼

<app-paging [pageIndex]="this.pageIndex" [pageCount]="this.pageCount" (change)="bindpage($event)"></app-paging>

父類綁定分頁數據ts代碼

  private bindpage(event:number):void {
    this.GetList.GetListPageBy_M2V3(event,this.comId).then(backobj =>{
      this.cvPaging.sourceCollection = backobj.List;
      this.pageIndex = backobj.PageIndex;
      this.pageCount = backobj.CountPage;
    });
  }

 

如果下載github上的源碼。可以好好看下M2V1組件源碼。這個組件演示全國的省市區信息併進行分頁,angular4的模塊化劃分還是做的非常好的。

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 想要成為合格的Java程式員或工程師到底需要具備哪些專業技能,面試者在面試之前到底需要準備哪些東西呢?本文陳列的這些內容既可以作為個人簡歷中的內容,也可以作為面試的時候跟面試官聊的東西,你可以把這些內容寫到你的簡歷中,當然更需要的是你在面試的時候向面試官展示這些專業技能。相信此文對正在尋覓Java程 ...
  • 寫在前面: 現在有很多開發webservice的方法以及框架,什麼cxf等,但是這些在你編寫服務類的時候都要用到註解這個功能。如果現在的jdk是1.4的,那麼就不能使用註解這個功能了。所以這裡可以用到axis這個工具。 1.所需jar包: 2.一般webservice在工作中,都是用在web項目中, ...
  • 2017/6/25 首先學習java最權威的就是官方的文檔了,今天從頭讀了文檔,把一些小細節理清楚。 變數 Java語言里的變數分以下4類: 1. Instance Variables: (Non-Static Fields) 就是類里非靜態的field 2. Class Variables: (S ...
  • 一、支付流程 微信開放平臺H5支付接入相關鏈接:https://pay.weixin.qq.com/wiki/doc/api/H5.php?chapter=15_4 相應的支付流程: 二、相關代碼 1、統一下單 2、驗簽(待續) ...
  • 5年前大學畢業之後(暴露年齡了),進入通信國企工作,做的是通信設備維護,倒騰內部系統,設備簡單維護的工作,複雜點的都外包給廠家和代維了,所以個人技能沒有得到提高,就這樣混過了5年,國企嘛,又炒不了你。期間也有很忙的時候,完成總公司的任務,加班加點的,這時候開始想,我加班加點到底為了什麼,工資不高,由 ...
  • import MySQLdb#引入mysql模塊class ManagerDB:#創建一個類 def __init__(self): self.db=None self.cursor=None self.connit() def connit(self):#鏈接資料庫 self.db=MySQLdb ...
  • 打完包的項目會出現在tatget目錄下 這裡我們把比較大的jar稱之為胖jar,小的稱為瘦jar 打成的包會有一個胖jar及一個瘦jar,瘦jar的話比較小因為沒有將項目所需要的jar加進去,裡面只有java編譯後的代碼!而胖jar是將我們項目中用到的jar包和代碼加到一起所以它的會比較大一些! ...
  • 機器學習實戰這本書是在python2.x的環境下寫的,而python3.x中好多函數和2.x中的名稱或使用方法都不一樣了,因此對原書中的內容需要校正,下麵簡單的記錄一下學習過程中fix的部分 1、print 函數後面需要加括弧(程式清單2-4開始出現print函數) 2、raw_input改為inp ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...