更新记录

1.1.1(2021-07-18)

测试一下修改插件的名称,tbs-tabbar-frame改为tbs-tabBar-frame。

1.1.0(2021-07-18)

完善了readme.md文件

查看更多

平台兼容性

Vue2 Vue3
×
App 快应用 微信小程序 支付宝小程序 百度小程序 字节小程序 QQ小程序
3.1.0 × × × × ×
钉钉小程序 快手小程序 飞书小程序 京东小程序 小红书小程序
× × × × ×
H5-Safari Android Browser 微信浏览器(Android) QQ浏览器(Android) Chrome IE Edge Firefox PC-Safari
× × × × × × × × ×

请注意:由于该组件引用了components中的组件,而此类components代码并未包含在本组件中,所以,请注意查看readme和示例代码

tbs-tabBar-frame 带自定义tabBar、并且可以“动态”加载页面模板的框架

组件名:tbs-tabBar-frame

说明

此框架是为了简化带tabBar组件的页面开发,同时,当tabBar切换时,此框架里的页面模板会对应更换,且已经加载过的内容不会重复刷新数据。

依赖的组件

1、tbs-tabBarInPage 在页面中生成tabBar的组件,该tabBar完全自定义,不受小程序2~5个tab的限制。

2、tbs-pages tbs-pages组件包含可以切换的多个页面,可配合tabBar或顶部scrollTab使用,实现在页面切换时,页面的内容及状态可以保持,每次切换到页面时,页面数据不会被重新加载。

安装方式

本组件符合easycom规范,HBuilderX 2.5.5起,只需将本组件导入项目,在页面template中即可直接使用,无需在页面中import和注册components

API

tbs-tabBar-frame Props

属性名 类型 默认值 说明
pages Object 传递给组件的页面数组对象数据
tabBar Object 传递给组件的tabBar数据

属性说明:

pages数据结构需要有一定的格式要求

该格式和tbs-pages组件一致,请参阅tbs-pages组件里的readme文件和demo

tabBar数据结构需要有移动的格式要求

该格式和tbs-tabBarInPage组件一致,请参阅tbs-tabBarInPage组件里的readme文件和demo

tbs-tabBar-frame Events

事件称名 说明 返回参数

属性说明: 无

基本用法

在调用组件的页面里编写如下代码: 在 template 中使用组件

<template>
    <view>
        <tbs-tabBar-frame :tabBar="tabBar" :pages="pages"/>
    </view>
</template>

scriptdata 中加入: tabBar变量、pages变量,由于考虑到pages组件要和tabBar组件的切换操作同步,所以pages组件的页数和tabBar的tab数相等。 tabBar变量,表示当前页面传给组件的自定义tabBar数据

data(){
    return{
        selected: 0,
        tabBar: { //此处为tabBar属性的demo演示数据,当然你可以根据需要进行修改
            selected: 0, // 当前选择的tab的index序号
            color: "#7A7E83", // 非选择项的字体颜色
            selectedColor: "#3cc51f", // 选择项的字体颜色
            list: [{ // tabBar 里的item项目列表
                // 此处图标icon的路径可以有两种表示方式,一种是图片路径格式,另一种是采用base64格式
                // 图片路径格式必须要保证路径下的文件是存在的,演示如下:
                // selectIconPath: "/static/images/tabbar/home-a.png",
                // iconPath: "/static/images/tabbar/home.png",
                // 下面是demo数据,为了便于使用测试,使用base64格式加载icon
                selectIconPath: "",
                iconPath: "",
                text: "首页"
            }, {
                selectIconPath: "",
                iconPath: "",
                text: "分类"
            }, {
                selectIconPath: "",
                iconPath: "",
                text: "发布"
            }, {
                selectIconPath: "",
                iconPath: "",
                text: "收藏"
            }, {
                selectIconPath: "",
                iconPath: "",
                text: "我的"
            }]
        }
    }
}

pages变量,表示当前页面传给组件的自定义pages数据

// 下面为pages属性的demo演示数据
pages: {
    current: 0, // 当前显示的页面的序号index
    list: [ // 页面数组
        {
            pageTmpl: 'testPage1', // 页面模板名称,必须
            pageData: { // 页面数据,必须
                text: '测试页面-1' // 此处的内容根据业务需要定义
            }
        }, 
        {
            pageTmpl: 'testPage2',
            pageData: {
                text: '测试页面-2'
            }
        }, 
        {
            pageTmpl: 'testPage3',
            pageData: {
                text: '测试页面-3'
            }
        }, 
        {
            pageTmpl: 'testPage4',
            pageData: {
                text: '测试页面-4'
            }
        }, 
        {
            pageTmpl: 'testPage5',
            pageData: {
                text: '测试页面-5'
            }
        }
    ]
}

scriptmethods 中编写事件方法代码 无

在测试项目的components下建立组件 此处建立的组件,需要符合easycom规范,这样就可以不用import就可以轻松被调用,示例代码组件有:

templates组件 该组件用来作为页面模板的“路由”,根据条件判断pageTmpl的值来决定加载哪一个页面模板,内容如下(实际根据需要修改): 在template里的代码如下:

<template>
    <view>
        <testPage1 v-if="page.pageTmpl==='testPage1'" :pageData="page.pageData" />
        <testPage2 v-if="page.pageTmpl==='testPage2'" :pageData="page.pageData" />
        <testPage3 v-if="page.pageTmpl==='testPage3'" :pageData="page.pageData" />
        <testPage4 v-if="page.pageTmpl==='testPage4'" :pageData="page.pageData" />
        <testPage5 v-if="page.pageTmpl==='testPage5'" :pageData="page.pageData" />
    </view>
</template>

script部分定义一个属性page

props: {
    page: Object
},

页面模板组件 示例代码中有5个页面模板组件:testPage1~testPage5,下面以testPage1组件为例介绍,其它几个组件同理 在template部分可以写任何需要的代码,此处示例为:

<template>
    <view>
        <!-- 循环100次,让数据可以充满列表,垂直滚动,测试换页时数据是否会重新刷新加载。希望切换页面时数据不刷新,达到要求! -->
        <view v-for='count in 100' :key="count">[{{count}}] - {{pageData.text}}</view>
    </view>
</template>

script部分定义一个属性pageData 此属性接收调用方传过来的页面数据

props: {
    pageData: Object
},

隐私、权限声明

1. 本插件需要申请的系统权限列表:

2. 本插件采集的数据、发送的服务器地址、以及数据用途说明:

插件不采集任何数据

3. 本插件是否包含广告,如包含需详细说明广告表达方式、展示频率:

许可协议

MIT协议

使用中有什么不明白的地方,就向插件作者提问吧~ 我要提问