跳转到内容

tabbar页

刀刀

12/30/2024

0 字

0 分钟

主页面 tabBar 页面根据高保真原型图设计开发即可。

首页轮播图跳转

用户有一个需求是点击轮播图的图片跳转到指定链接页面,UniApp 有一个内置的组件 webview 。根据官方文档,为其 src 设置指定的网页链接后可跳转到该页面。可能常用属性如下:

属性名类型说明
srcStringwebview 指向网页的链接
webview-stylesObjectwebview 的样式

更多属性前往官网查看。

实现步骤如下:

  • 点击轮播图路由跳转

  • 拿到链接参数赋给 src 属性

js
const swiperToPage = e => {
  // 如果有参数再跳转
	if (!e) return
	uni.navigateTo({
		url: `/pages/routerWebView/RouterWebView?src=${e}`
	})
}
vue
<script setup>
import {ref} from 'vue'

const webviewStyles = ref({
	top: 0
})
const src = ref('')

onLoad((val) => {
	src.value = val.src
})
</script>

<template>
	<web-view :webview-styles="webviewStyles" :src="src"></web-view>
</template>

更多 webview 使用技巧可参考官网文档、DCloud上的问答 在web-view加载的本地及远程HTML中调用uni的API及网页和vue页面通讯 与这两篇文章 在uniapp中优雅地使用WebViewwebview使用

tabbar隐藏

原生 tabbar 层级极高,即使通过 css 为元素设置 z-index 为9999都无法覆盖。而本项目中需要进入页面判断用户是否复制了领取优惠券的码,如果有则不展示下方的 tabbar 。不然会有一个 bug :在首页展示了领取优惠券的模态框,不点击去往我的页面,我的页面也展示。返回首页取消掉模态框后我的页面的模态框并没有取消掉。

如果无法从层级方面下手,能否从显隐方面呢?查看官方文档发现有对应的显示 tabbar 方法 showTabBar() 和隐藏 tabbar 方法 hideTabBar()

js
onShow(() => {
	setTimeout(() => {
		if (如果有复制到优惠券码) {
			uni.hideTabBar()
			id.value = uni.getStorageSync('couponShow')
			// 做其他处理
		}
	}, 500)
})

const closeFn = () => {
	// 移出本地存储,清除复制的内容,隐藏弹窗
	uni.removeStorageSync('couponShow')
	uni.setClipboardData({
		data: '',
		showToast: false,
		success: function() {
		}
	});
	show.value = false
	uni.showTabBar()
}

现在的效果如下所示:

p9gWBi4.png