it编程 > App开发 > uniapp

uniapp 自定义tabBar

142人参与 2024-08-03 uniapp

1.修改pages.json文件中tabbar内容:

只需要添加"custom":true,//自定义tabbar即可

2.创建组件tabbar

<template>
	<view class="tabbar">
		<view v-for="(item, index) in tabbarlist" :key="index" class="tabbar-item" @click="switchtab(index)">
			<text :class="{active: index === currentindex}">{{item.text}}</text>
		</view>
	</view>
</template>
 
<script>
export default {
	props: {
		currentindex: number
	},
	data(){
		return{
			tabbarlist: [
				{ text: '首页', icon: '', activeicon: '' },
				{ text: '店铺', icon: '', activeicon: '' },
				{ text: '购物车', icon: '', activeicon: '' },
				{ text: '我的', icon: '', activeicon: '' }
			],
		}  
	},
	methods: {
		switchtab(index) {
		  this.$emit('switchtab', index);
		}
	}
}
</script>
 
<style scoped>
	.tabbar {
		display: flex;
		position: fixed;
		bottom: 0;
		left: 0;
		right: 0;
		background-color: #fff;
		height: 80px;
		border-top: 1px solid #999;
	}
	.tabbar-item {
		flex: 1;
		display: flex;
		justify-content: center;
		align-items: center;
		position: relative;
	}
	.tabbar-item text {
		padding: 5px;
		font-size: 14px;
		color: #333;
	}
	.tabbar-item text.active {
		color: #09bb07;
	}
</style>

 3.引用组件

在首页引用组件

<template>
	<view class="content">
		<tabbar  :currentindex="currentindex" @switchtab="switchtab"></tabbar>
	</view>
</template>

<script>
	import tabbar from '@/components/tabbar/tabbar.vue'
	export default {
		components:{
			tabbar
		},
		data() {
			return {
				currentindex: 0
			}
		},
		created() {},
		onload() {},
		methods: {
			switchtab(index) {
				this.currentindex = index;// 根据index切换对应的页面
			}
		}
	}
</script>

<style>
	
</style>

 

(0)
打赏 微信扫一扫 微信扫一扫

您想发表意见!!点此发布评论

推荐阅读

封装webSocket(uniapp)

08-03

uniapp视频层级问题

08-02

WPF HandyControl 界面交互反馈:对话框+加载框+列表选择

08-02

uniapp中自定义tabbar无法跳转?如何解决

08-06

【uniapp】开发微信小程序自定义底部tabbar

08-01

App前端开发跨平台框架比较:React Native、Flutter、Xamarin等

07-28

猜你喜欢

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论