上一章节的认识

上一章节我们主要认识了pages.json配置文件中的pages和globalStyle代表的含义,本章节主要说一下经常使用的tabBar组件,tabBar组件和pages、globalStyle也是平级的。
这里看看我们直接的代码

{
	"pages": [ //pages数组中第一项表示应用启动页,参考:https://uniapp.dcloud.io/collocation/pages
		{
		"path": "pages/index/index",
		"style": {
				//"navigationBarTitleText": "uni-app"
			}
		}
	],
	"globalStyle": {
		"navigationBarTextStyle": "black",
		"navigationBarTitleText": "uni-app测试",
		"navigationBarBackgroundColor": "#55aa7f",
		"backgroundColor": "#F8F8F8"
	}
}

效果展示

我们在使用tabBar组件之前先看一下最终的效果

uniapp ios里alert无用 uniapp tabbar_uniapp ios里alert无用


uniapp ios里alert无用 uniapp tabbar_ico_02


uniapp ios里alert无用 uniapp tabbar_多平台开发_03

整理思路

看完了是不是觉得在很多地方都看过呀,话不多说 开始撸代码(撸起袖子开始干)吧。
干之前我们选撸撸思路吧

  1. 因为有了新的三个页面,所以我们肯定要创建三个页面
  2. 在页面配置项将三个页面配置成tabBar组件形式
  3. 在首页设置一个方法,跳转到三个页面的其中一个页面
创建页面

点击项目右键——>新建页面(默认模板即可)

三个页面分别为tab1、tab2、tab3

uniapp ios里alert无用 uniapp tabbar_uniapp ios里alert无用_04


三个页面新建完毕之后,我们打开page.json文件看一看。

uniapp ios里alert无用 uniapp tabbar_ico_05


上图可以看到在这个文件内,uniapp自动为我们添加了这三个页面,真的是好贴心哦,若是想单独设置每个页面的标题、颜色等属性,则在style中直接设置即可。

然后我们在官方文档中找到这tabBar组件

https://uniapp.dcloud.io/collocation/pages?id=tabbar 代码如下:

{
	"pages": [ //pages数组中第一项表示应用启动页,参考:https://uniapp.dcloud.io/collocation/pages
		{
			"path": "pages/index/index",
			"style": {
				//"navigationBarTitleText": "uni-app"
			}
		}
	    ,{
            "path" : "pages/tab1/tab1",
            "style" : {}
        }
        ,{
            "path" : "pages/tab2/tab2",
            "style" : {}
        }
        ,{
            "path" : "pages/tab3/tab3",
            "style" : {}
        }
    ],
	"globalStyle": {
		"navigationBarTextStyle": "black",
		"navigationBarTitleText": "uni-app测试",
		"navigationBarBackgroundColor": "#55aa7f",
		"backgroundColor": "#F8F8F8"
	},
	
	"tabBar": {
	    "color": "#7A7E83",
	    "selectedColor": "#3cc51f",
	    "borderStyle": "black",
	    "backgroundColor": "#ffffff",
	    "list": [{
	        "pagePath": "pages/tab1/tab1",
	        "iconPath": "static/image/about.png",
	        "selectedIconPath": "static/image/about_sel.png",
	        "text": "关于我们"
	    }, {
	        "pagePath": "pages/tab2/tab2",
	        "iconPath": "static/image/call.png",
	        "selectedIconPath": "static/image/call_sel.png",
	        "text": "联系我们"
	    },
		{
		    "pagePath": "pages/tab3/tab3",
		    "iconPath": "static/image/default1.png",
		    "selectedIconPath": "static/image/default1_sel.png",
		    "text": "智慧城市"
		}
		]
	}
}

图片这里我们在阿里巴巴的字体网站中下载几个png字体即可使用。

序号

属性名

属性意思

1

pagePath

跳转的页面路径

2

iconPath

默认的图片路径

3

selectedIconPath

选中时候图片路径

4

text

页面名称

展示效果
方法一

最后我们可以将pages/tab1/tab1放在pages数组中的第一位即可展示出来。

uniapp ios里alert无用 uniapp tabbar_uniapp ios里alert无用_06

方法二

也可以通过在index/index的method方法中添加一个跳转方法

uniapp ios里alert无用 uniapp tabbar_uni-app_07


此方法可能牵涉到Vue的开发,若您不了解Vue的开发方式,建议可以去Vue官方网站学习一波。

这里说一下uni.switchTab方法,该方法只适用于跳转到tabBar页面上,而且是不能携带参数的,跳转到 tabBar 页面只能使用 switchTab 跳转

若是跳转到普通页面,
则直接使用uni.navigateTo(OBJECT)或者uni.redirectTo(OBJECT)

  1. uni.redirectTo(OBJECT)
    关闭当前页面,跳转到应用内的某个页面。(可以传参数)
    举个栗子:
uni.redirectTo({
    url: 'test?id=1'
});
  1. uni.redirectTo(OBJECT)
    关闭当前页面,跳转到应用内的某个页面
uni.redirectTo({
    url: 'test?id=1'
});
  1. uni.reLaunch(OBJECT)
    关闭所有页面,打开到应用内的某个页面。
uni.reLaunch({
    url: 'test?id=1'
});

补充知识

传入的参数,在新的页面中可以使用onload方法进行接收。
举个栗子:

//在起始页面跳转到test.vue页面并传递参数
uni.navigateTo({
    url: 'test?id=1&name=uniapp'
});
// 在test.vue页面接受参数
export default {
    onLoad: function (option) { //option为object类型,会序列化上个页面传递的参数
        console.log(option.id); //打印出上个页面传递的参数。
        console.log(option.name); //打印出上个页面传递的参数。
    }
}