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

angularjs+bootstrap實(shí)現(xiàn)自定義分頁(yè)的實(shí)例代碼

 更新時(shí)間:2017年06月19日 14:32:58   作者:白虎先生  
本篇文章主要介紹了angularjs+bootstrap實(shí)現(xiàn)自定義分頁(yè)的實(shí)例代碼,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

目前在做一個(gè)java web頁(yè)面,沒(méi)有使用到框架的分頁(yè),所以需要自己實(shí)現(xiàn)分頁(yè),就想到了用angularjs來(lái)實(shí)現(xiàn)分頁(yè),數(shù)據(jù)通過(guò)ajax從后臺(tái)獲取。

插件

百度了一下,看到一個(gè)比較漂亮的插件,就直接用該插件,并修改了部分細(xì)節(jié),使得適合我的項(xiàng)目,該插件地址是:(https://github.com/miaoyaoyao/AngularJs-UI

效果圖


使用方法

1、在網(wǎng)頁(yè)的頭部引入angularjs、bootstarp以及該插件,該分頁(yè)插件主要是ng-pagination.css以及ng-pagination.js

<link rel="stylesheet" href="/nutz-test/static/bootstrap/bootstrap.min.css" rel="external nofollow" >
<link rel="stylesheet" href="/nutz-test/static/angular/ng-pagination.css" rel="external nofollow" >
<script src="/nutz-test/static/jquery/jquery.min.js"></script>
<script src="/nutz-test/static/angular/angular.min.js"></script>
<script src="/nutz-test/static/angular/ng-pagination.js"></script>
<script src="/nutz-test/static/bootstrap/bootstrap.min.js"></script>

2、表格代碼以及分頁(yè)代碼

<div id="app" ng-app="myApp" ng-controller="myCtrl">
 <div style="overflow: auto; width: 100%;">
   <table class="table table-hover table-striped table-bordered" id="j-table">
     <thead>
       <tr>
         <th>姓名</th>
         <th>年齡</th>
         <th>電話</th>
         <th>職位</th>
       </tr>    
     </thead>
     <tbody>
       <tr ng-repeat="item in list">
         <th title="{{item.name}}">{{item.name}}</th>
         <th title="{{item.age}}">{{item.age}}</th>
         <th title="{{item.tel}}">{{item.tel}}</th>
         <th title="{{item.position}}">{{item.position}}</th>
       </tr>
     </tbody>
   </table>
 </div>
<!-- 這里引用插件的分頁(yè)-->
 <div class="pager">
  <pager page-count="pageCount" current-page="currentPage" on-page-change="onPageChange()" first-text="首頁(yè)" next-text="下一頁(yè)" prev-text="上一頁(yè)" last-text="尾頁(yè)" show-goto="true" goto-text="跳轉(zhuǎn)到"></pager>
 </div>
</div>

3、javascript代碼部分

分頁(yè)的重點(diǎn)是從后臺(tái)獲取數(shù)據(jù),只需把pageSize(每頁(yè)顯示數(shù)目),以及pageIndex(當(dāng)前頁(yè)數(shù))通過(guò)post請(qǐng)求傳到后臺(tái)即可。后臺(tái)返回實(shí)際的數(shù)據(jù)以及pageCount(頁(yè)數(shù))給前臺(tái)即可。其中,onPageChange()方法是點(diǎn)擊頁(yè)碼后去通過(guò)ajax從后臺(tái)獲取數(shù)據(jù),myinit()方法是第一次請(qǐng)求該頁(yè)面時(shí)進(jìn)行初始化。$scope.currentPage就是頁(yè)數(shù),例如當(dāng)你點(diǎn)擊下一頁(yè)的時(shí)候,它就會(huì)加一,然后就可以通過(guò)post請(qǐng)求去后臺(tái)取下一頁(yè)的數(shù)據(jù)了。

<script type="text/javascript">
var app = angular.module('myApp', ['ng-pagination']);
app.controller('myCtrl', ['$scope', function ($scope) {
  $scope.onPageChange = function() {
     // ajax request to load data
     console.log($scope.currentPage);
     //這里是post請(qǐng)求去后臺(tái)取數(shù)據(jù)
     $.ajax({
       type:"post",
       url:'/nutz-test/show/pagination',
       data:{
         "pageSize":5,
         "pageIndex":$scope.currentPage
       },
       dataType:"json",
       success:function(data){
         $scope.$apply(function () {
           $scope.list = data.list;
           $scope.pageCount = data.pageCount;
          });

       }
     })
    };
    //初始化,設(shè)置為第一頁(yè),每頁(yè)顯示5條
    $scope.myinit = function(){
      $.ajax({
         type:"post",
         url:'/nutz-test/show/pagination',
         data:{
           "pageSize":5,
           "pageIndex":1
         },
         dataType:"json",
         success:function(data){
           $scope.$apply(function () {
             $scope.list = data.list;
             $scope.pageCount = data.pageCount;
            });

         }
       })
    };
    $scope.myinit();
}]);
</script>

注意事項(xiàng)

1、該插件在只有一頁(yè)的情況會(huì)出現(xiàn)分頁(yè)插件加載不出來(lái)的情況,因此需要修改ng-pagination.js的代碼。

打開(kāi)ng-pagination.js,定位到最后的template,修改pageCount>=1,如下圖所示。

2、在ie瀏覽器和360瀏覽器不支持跳轉(zhuǎn)功能,原因是ie和360沒(méi)有number.isNaN()方法,因此需要修改分頁(yè)插件的該方法,改為isNaN()。

定位到ng-pagination.js的Number.isNaN()方法,把該方法修改為下圖所示。

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • AngularJS實(shí)現(xiàn)Input格式化的方法

    AngularJS實(shí)現(xiàn)Input格式化的方法

    這篇文章主要介紹了AngularJS實(shí)現(xiàn)Input格式化的方法,結(jié)合實(shí)例形式分析了AngularJS實(shí)現(xiàn)Input格式化的操作步驟與相關(guān)注意事項(xiàng),需要的朋友可以參考下
    2016-11-11
  • 深入淺析AngularJS中的module(模塊)

    深入淺析AngularJS中的module(模塊)

    我們所說(shuō)的模塊,是你的AngularJS應(yīng)用程序的一個(gè)組成部分,它可以是一個(gè)Controller,也可以是一個(gè)Service服務(wù),也可以是一個(gè)過(guò)濾器(Filter),也可以是一個(gè)directive(指令)等等…都是屬于一個(gè)模塊,本文給大家介紹AngularJS中的module(模塊) ,感興趣的朋友一起學(xué)習(xí)吧
    2016-01-01
  • Angular4項(xiàng)目中添加i18n國(guó)際化插件ngx-translate的步驟詳解

    Angular4項(xiàng)目中添加i18n國(guó)際化插件ngx-translate的步驟詳解

    這篇文章主要跟大家介紹了關(guān)于Angular4項(xiàng)目中添加i18n國(guó)際化插件ngx-translate的步驟,文中介紹的非常詳細(xì),對(duì)大家具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起看看吧。
    2017-07-07
  • 簡(jiǎn)述AngularJS的控制器的使用

    簡(jiǎn)述AngularJS的控制器的使用

    這篇文章主要介紹了AngularJS的控制器的使用,文中給出了具體的用于HTML中的對(duì)象示例,需要的朋友可以參考下
    2015-06-06
  • 詳解在Angular項(xiàng)目中添加插件ng-bootstrap

    詳解在Angular項(xiàng)目中添加插件ng-bootstrap

    這篇文章主要介紹了詳解在 Angular 項(xiàng)目中添加插件 ng-bootstrap,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-07-07
  • AngularJS equal比較對(duì)象實(shí)例詳解

    AngularJS equal比較對(duì)象實(shí)例詳解

    這篇文章主要介紹了AngularJS API之equal比較對(duì)象的相關(guān)資料,需要的朋友可以參考下
    2016-09-09
  • AngularJS應(yīng)用開(kāi)發(fā)思維之依賴注入3

    AngularJS應(yīng)用開(kāi)發(fā)思維之依賴注入3

    這篇文章主要為大家詳細(xì)介紹了AngularJS應(yīng)用開(kāi)發(fā)思維之依賴注入第三篇,感興趣的小伙伴們可以參考一下
    2016-08-08
  • 詳解Angular中延遲加載的原理與使用

    詳解Angular中延遲加載的原理與使用

    Angular 是一個(gè)流行的框架,用于構(gòu)建動(dòng)態(tài)和響應(yīng)式 Web 應(yīng)用程序,在本文中,我們將討論延遲加載以及它如何與 Angular 中的路由一起工作,感興趣的可以跟隨小編一起學(xué)習(xí)一下
    2023-06-06
  • Angular實(shí)現(xiàn)form自動(dòng)布局

    Angular實(shí)現(xiàn)form自動(dòng)布局

    這篇文章主要介紹了Angular實(shí)現(xiàn)form自動(dòng)布局的相關(guān)資料,以代碼片段的形式分析了Angular實(shí)現(xiàn)form自動(dòng)布局的實(shí)現(xiàn)方法,感興趣的小伙伴們可以參考一下
    2016-01-01
  • angularjs 頁(yè)面自適應(yīng)高度的方法

    angularjs 頁(yè)面自適應(yīng)高度的方法

    本篇文章主要介紹了angularjs 頁(yè)面自適應(yīng)高度的方法,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-01-01

最新評(píng)論