【永恒的瞬间】
☜Give me hapy ☞
DataGrid分页[原创]

<?xml version="1.0"?>
<mx:Application xmlns:mx="http://www.macromedia.com/2003/mxml" backgroundColor="#FFFFFF" creationComplete="initApp()">

   <mx:Script>
       <![CDATA[
                 var pageRecordes:Number;
                 var totalPages:Number = 0;
                 var totalRows:Number = 0;
                 var currentPage:Number = 1;
                 var pageStartRow:Number = 1;
                 var pageEndRow:Number = 0;
                 
           public var initDG:Array = [
               { Artist: a, Price: 1, Album: one},
                       { Artist: b, Price: 2, Album: two},
                       { Artist: c, Price: 3, Album: three},
                       { Artist: d, Price: 4, Album: four},
                       { Artist: e, Price: 5, Album: five},
                       { Artist: f, Price: 6, Album: six},
                       { Artist: g, Price: 7, Album: seven},
               { Artist: h, Price: 8, Album: eight} ];
                       
                 function initApp(){
                       txt.text = "Page " + currentPage;
                       pageRecordes = pageConfig.pageRecordes;
                       totalRows = initDG.length;
                       if(initDG.length > pageRecordes){
                             dg.dataProvider = initDG.slice(0,pageRecordes);
                             pPage.enabled = false;
                       }
                       
                       if ((totalRows % pageRecordes) == 0) {
                             totalPages = Math.floor(totalRows / pageRecordes);
                       } else {
                             totalPages = Math.floor(totalRows / pageRecordes + 1);
                       }
                       
                       if (totalRows <= pageRecordes) {
                             this.pageStartRow = 1;
                             this.pageEndRow = totalRows;
                       } else {
                             this.pageStartRow = 1;
                             this.pageEndRow = pageRecordes;
                       }
                       
                       if(totalPages == 1){
                             pPage.enabled = false;
                             nPage.enabled = false;
                       }
                 }
          
                 function showPreviousPage(){
                       currentPage = currentPage - 1;
                       txt.text = "Page " + currentPage;
                       if(currentPage == 1){
                             pPage.enabled = false;
                             nPage.enabled = true;
                       }else{
                             pPage.enabled = true;
                             nPage.enabled = true;
                       }
                       if (currentPage == totalPages) {
                             pageStartRow = (currentPage - 1) * pageRecordes + 1;
                             pageEndRow = totalRows;
                       } else {
                             pageStartRow = (currentPage - 1) * pageRecordes + 1;
                             pageEndRow = currentPage * pageRecordes;
                       }
                       dg.dataProvider = initDG.slice(pageStartRow - 1,pageEndRow);
                 }
                 
                 function showNextPage(){
                       currentPage = currentPage + 1;
                       txt.text = "Page " + currentPage;
                       if(currentPage == totalPages){
                             nPage.enabled = false;
                             pPage.enabled = true;
                       }else{
                             nPage.enabled = true;
                             pPage.enabled = true;
                       }
                       if (currentPage == totalPages) {
                             pageStartRow = (currentPage - 1) * pageRecordes + 1;
                             pageEndRow = totalRows;
                       } else {
                             pageStartRow = (currentPage - 1) * pageRecordes + 1;
                             pageEndRow = currentPage * pageRecordes;
                       }
                       dg.dataProvider = initDG.slice(pageStartRow - 1,pageEndRow);
                 }
                 
       ]]>
   </mx:Script>
     
     <mx:Model id="pageConfig" source="WEB-INF/classes/pageConfig.xml"/>
   <mx:Panel title="DataGrid Panel" marginTop="10" height="100%" width="100%">

       <mx:DataGrid id="dg" dataProvider="{initDG}" height="100%" width="100%" />
           <mx:HBox>
                 <mx:Button id="pPage" label="prevPage" click="showPreviousPage()"></mx:Button>
                 <mx:Text id="txt"></mx:Text>
                 <mx:Button id="nPage" label="nextPage" click="showNextPage()"></mx:Button>
           </mx:HBox>

   </mx:Panel>

</mx:Application>

还有一个配置的xml文件,路径是:...WEB-INF/classes/pageConfig.xml
该xml文件内容如下:
<?xml version="1.0" encoding="shift_jis"?>
<web-app>
     <pageRecordes>3</pageRecordes>
</web-app>

posted on 2007-02-28 13:48 ☜♥☞MengChuChen 阅读(444) 评论(0)  编辑  收藏 所属分类: flex2.0

只有注册用户登录后才能发表评论。


网站导航: