wychao 2013-07-03 16:57:21 6803次浏览 1条回复 0 0 0

上次在群里看到有人问这个功能,最近我也有这个需求,刚好发给贴吧。。 非我原创。

TbMixPager :

<?php
Yii::import('bootstrap.widgets.TbPager');
class TbMixPager extends TbPager
{

    public $alignment = TbPager::ALIGNMENT_RIGHT;

    public function run(){
        $this->maxButtonCount=5;
        $this->registerClientScript();
        $buttons=$this->createPageButtons();
        if(empty($buttons))
            return;
        echo $this->header;
        echo CHtml::tag('ul',$this->htmlOptions,implode("\n",$buttons));
        echo $this->footer;
        echo $this->controller->widget('comcom.widgets.TbJumpPager',
            array('pages' => $this->pages,
                'ajaxUpdate' => true,
                'cssClass' => 'pull-right'),
            true);
    }
}

<?php
class TbJumpPager extends TbPager
{

    /**
     * @var string the text shown before page buttons. Defaults to 'Go to page: '.
     */
    public $prependLabel = '到第';
    /**
     * @var string
     */
    public $afterLabel = '页';

    /**
     * @var string the text shown after page buttons.
     */
    public $appendLabel = '确定';


    /**
     * @var int
     */
    public $pageSizeTpl = 999999;

    /**
     * @var string
     */
    public $viewContainer = 'body';

    /**
     * @var string name of the GET variable storing the current page index. Defaults to 'page'.
     * ------------------------------------
     * should be same as your pagination 's
     * ------------------------------------
     */
    public $pageVar = 'page';

    /**
     * @var bool
     */
    public $ajaxUpdate = false;

    /**
     * @var string
     */
    public $cssClass = __CLASS__;


    /**
     *
     */
    public function init()
    {
        $this->pageVar = $this->pages->pageVar;
    }

    /**
     * @var array
     */
    /**
     * Executes the widget.
     * This overrides the parent implementation by displaying the generated page buttons.
     */
    public function run()
    {
        /*
         * must register the js firstly !!!
         if (($pageCount = $this->getPageCount()) <= 1)
             return;
         */

        /**
         * the created pagerNumber will be 1000
         */
        $pageUrlTemplate = $this->createPageUrl($this->pageSizeTpl);

        $thisCssClass = $this->cssClass;

        $jsNameSpace = __CLASS__;

        $jumpForm = <<<EOD
        <div class="input-prepend input-append {$thisCssClass}" >
            <span class="add-on">{$this->prependLabel}</span>
             <input class="span1" type="text"/>
            <span class="add-on">{$this->afterLabel}</span>
            <button class="btn" onclick="{$jsNameSpace}.goPage(this)" type="button" page-url="{$pageUrlTemplate}">{$this->appendLabel}</button>
        </div>

EOD;
        echo $jumpForm;
        $pageSizeTpl = $this->pageSizeTpl + 1;

        $ajaxUpdate = CJavaScript::encode($this->ajaxUpdate);


        $js = <<<ON_JUMP
        var {$jsNameSpace} = {};
        {$jsNameSpace}.goPage = function(el){
           var toPage = $(el).parents('.{$this->cssClass}').find(':input').val();
               var ajaxUpdate = {$ajaxUpdate};
                    var er = /^[0-9]+$/;
                    if(er.test(toPage)){
                        if(ajaxUpdate){
                           jumpToPageAjax(toPage)
                        }else{
                            jumpToPage(toPage);
                        }
                        /*
                         var pageUrl = $(this).attr("page-url");
                         pageUrl = pageUrl.replace('{$pageSizeTpl}',toPage);
                         //alert(pageUrl);
                         window.location = pageUrl;
                         */
                    }else{
                         alert("must be a number");
                    }
        }
        function jumpToPage(page){
            //probe the gridView or listView id
            var listViewClass = '.list-view';
            var gridViewClass = '.grid-view';
            var viewContainerSelector  = "{$this->viewContainer}";
            var XViewId;
            var pageUrl ;
            if ($(listViewClass,  $(viewContainerSelector)).size() > 0) {
                XViewId = $(listViewClass, $(viewContainerSelector)).attr('id');
                pageUrl = $.fn.yiiListView.getUrl(XViewId);

                //handle the url String ,  pathInfo and queryString
                pageUrl = pageUrl.replace(/{$this->pageVar}\/\d+/, "{$this->pageVar}/"+page);
                pageUrl = pageUrl.replace(/{$this->pageVar}=\d+/, "{$this->pageVar}="+page);
            } else if ($(gridViewClass,  $(viewContainerSelector)).size() > 0) {
                XViewId = $(gridViewClass,  $(viewContainerSelector)).attr('id');
                pageUrl = $.fn.yiiGridView.getUrl(XViewId);
                //handle the url String ,  pathInfo and queryString
                pageUrl = pageUrl.replace(/{$this->pageVar}\/\d+/, "{$this->pageVar}/"+page);
                pageUrl = pageUrl.replace(/{$this->pageVar}=\d+/, "{$this->pageVar}="+page);
                alert(pageUrl);
            }
            window.location = pageUrl;
        }
        function jumpToPageAjax(page){
            //probe the gridView or listView id
            var listViewClass = '.list-view';
            var gridViewClass = '.grid-view';
            var viewContainerSelector  = "{$this->viewContainer}";
            var XViewId;
            if ($(listViewClass,  $(viewContainerSelector)).size() > 0) {
                XViewId = $(listViewClass, $(viewContainerSelector)).attr('id');
                var url = $.fn.yiiListView.getUrl(XViewId);

                //handle the url String ,  pathInfo and queryString
                url = url.replace(/{$this->pageVar}\/\d+/, "{$this->pageVar}/"+page);
                url = url.replace(/{$this->pageVar}=\d+/, "{$this->pageVar}="+page);

                $.fn.yiiListView.update(XViewId,{url:url,data:{"{$this->pageVar}":page }} );

            } else if ($(gridViewClass,  $(viewContainerSelector)).size() > 0) {
                XViewId = $(gridViewClass,  $(viewContainerSelector)).attr('id');
                var url = $.fn.yiiGridView.getUrl(XViewId);
                //handle the url String ,  pathInfo and queryString
                url = url.replace(/{$this->pageVar}\/\d+/, "{$this->pageVar}/"+page);
                url = url.replace(/{$this->pageVar}=\d+/, "{$this->pageVar}="+page);

                $.fn.yiiGridView.update(XViewId,{url:url,data:{"{$this->pageVar}":page }} );
            }
        }
ON_JUMP;
        Yii::app()->clientScript->registerScript(__CLASS__, $js, CClientScript::POS_END);
        /*
          if(Yii::app()->getRequest()->getIsAjaxRequest()){
             echo CHtml::script($js);
          }else{
              cs()->registerScript(__CLASS__,$js,CClientScript::POS_END);
          }
        */

    }
}

最后你需要修改bootstrap下的TbGridView

//public $pager = array('class' => 'bootstrap.widgets.TbPager');
public $pager = array('class' => 'bootstrap.widgets.TbMixPager');

最后吐槽一下。。 为什么论坛不能上传文件和图片?

您需要登录后才可以回复。登录 | 立即注册