Yii2使用Tabs标签(选项卡)实现切换

敬请收藏地址:https://www.wuflower.cn

使用Yii2相信有遇到过做Tab标签(选项卡)的,昨天翻了半天Yii2官网、各种教程、指导,结果,越看越懵,各种帖子也只是照搬来了一下官网,曹操有言可喻:‘鸡肋’,没有喷别人帖子的意思,不要打我~~~~

话不多说,直接开始吧!

1.业务场景:一个页面同时展示不同列表及搜索表单、分页信息,并且Tab标签需要显示每个列表总数

2.效果:

  

3.上菜:

<?php

//三个dataProvider,三个SearchModel
$dataProviderXXX1->setSort(false);
$dataProviderXXX1->pagination->defaultPageSize = 10;
$dataProviderXXX2->setSort(false);
$dataProviderXXX2->pagination->defaultPageSize = 10;
$dataProviderXXX3->setSort(false);
$dataProviderXXX3->pagination->defaultPageSize = 10;

?>



<!--Tabs Start-->
<?php
echo \yii\bootstrap\Tabs::widget([
    'id' => 'tabs',
    'renderTabContent' => false,
    'linkOptions' => ['data-toggle' => "tab"],
    'items' => [
        [
            'label' => Yii::t('app', 'XXX1('.$dataProviderAll->totalCount.')'),
            'content' => '',
            'headerOptions' => ["id" => 'li_all'],
            'url' => '#tab_all',
            'active' => true,
        ],
        [
            'label' => Yii::t('app', 'XXX2('.$dataProviderWait->totalCount.')'),
            'content' => '',
            'headerOptions' => ["id" => 'li_wait'],
            'url' => '#tab_wait',
            'active' => false,
        ],
        [
            'label' => Yii::t('app', 'XXX3('.$dataProviderAuth->totalCount.')'),
            'content' => '',
            'headerOptions' => ["id" => 'li_auth'],
            'url' => '#tab_auth',
            'active' => false,
        ]
    ]
]) ?>

<!--Tabs List Start-->
<div class="tab-content">

    <!--XXX1-->
    <div class="tab-pane active" id="tab_XXX1">

        //XXX1搜索表单
        <div class="row">
            <?php echo $this->render('_search', ['model' => $searchModelXXX1]); ?>
        </div>

        //XXX1列表
        <?= GridView::widget([
            'dataProvider' => $dataProviderXXX1,
            'columns' => [

                //XXXX1列表....

            ]   
        ]); ?>
    </div>

    <!--XXX2-->
    <div class="tab-pane" id="tab_XXX2">
        
        //XXX2搜索
        <div class="row">
            <?php echo $this->render('_XXX2-search', ['model' => $searchModelXXX2]); ?>
        </div>
        
        //XXX2列表
        <?= GridView::widget([
            'dataProvider' => $dataProviderXXX2,
            'columns' => [
                
                //XXX2列表.....

            ]
        ]); ?>
    </div>

    <!--XXX3-->
    <div class="tab-pane" id="tab_XXX3">
        
        //XXX3搜索表单
        <div class="row">
            <?php echo $this->render('_XXX3-search', ['model' => $searchModelXXX3]); ?>
        </div>

        //XXX3列表
        <?= GridView::widget([
            'dataProvider' => $dataProviderXXX3,
            'columns' => [
                
                //XXX3列表
    
            ]
        ]); ?>
    </div>

</div>
<!--Tabs List End-->
<!--Tabs End-->

4.XXX1,XXX2,XXX3的地方名称一致即可,Tabs标签可随意增加

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
Yii2使用Select2实现二级联动可以通过以下步骤实现: 1. 首先在视图文件中引入Select2组件: ```php use yii\helpers\Html; use kartik\select2\Select2; ``` 2. 定义一个数组来存储一级选项的数据,假设我们的数组为$parentData: ```php $parentData = ['1' => 'Parent 1', '2' => 'Parent 2', '3' => 'Parent 3']; ``` 3. 在视图文件中使用Select2组件来渲染一级选项: ```php echo $form->field($model, 'parent_id')->widget(Select2::classname(), [ 'data' => $parentData, 'options' => ['placeholder' => 'Select parent'], ]); ``` 4. 定义一个二维数组来存储二级选项的数据,假设我们的数组为$childData: ```php $childData = [ '1' => ['1-1' => 'Child 1-1', '1-2' => 'Child 1-2'], '2' => ['2-1' => 'Child 2-1', '2-2' => 'Child 2-2', '2-3' => 'Child 2-3'], '3' => ['3-1' => 'Child 3-1'], ]; ``` 5. 在视图文件中使用jQuery脚本来实现二级联动: ```php $script = <<< JS $(document).ready(function() { $('#model-parent_id').on('change', function() { var parent_id = $(this).val(); var childData = $.parseJSON('{$childData}'); $('#model-child_id').html(''); $.each(childData[parent_id], function(id, name) { var opt = $('<option/>').attr('value', id).text(name); $('#model-child_id').append(opt); }); }); }); JS; $this->registerJs($script); ``` 6. 在视图文件中使用Select2组件来渲染二级选项: ```php echo $form->field($model, 'child_id')->widget(Select2::classname(), [ 'options' => ['placeholder' => 'Select child'], ]); ``` 注意,我们在二级选项的Select2组件中并没有设置数据源,而是通过jQuery脚本来动态生成选项。此外,我们还需要在一级选项的Select2组件中添加`id`属性,以便在jQuery脚本中使用`$('#model-parent_id')`来获取选项的值。 以上就是使用Select2实现Yii2下的二级联动的步骤。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值