uniapp监听滚动实现顶部透明度变化

 效果如图:

实现思路:

1、使用onPageScroll监听页面滚动,改变导航条的透明度;

2、关于顶部图片的高度:

如果是小程序:使用getMenuButtonBoundingClientRect获取胶囊顶部距离和胶囊高度;

如果是H5:给个自定义高度就行;

3、透明度opacity的计算公式:1 - (this.imgHeight - e.scrollTop) / this.imgHeight;

4、相关组件绑定行内样式,完活!

完整代码:

<template>
	<view class="">

		<!-- 顶部导航 -->
		<fa-navbar :title="vuex_table_title || '宝乐名车服务'" ref="navbar"
			:style="[{opacity:opacity},{position:'fixed'},{'zIndex':'999'}]"></fa-navbar>
		<!-- 顶部图片 -->
		<view class="head_img" :style="[{overflow: 'hidden'},{height:imgHeight+'px'}]">
			<img :style="{width: '100%'}"
				src="https://sa.ffep.online:20093/uploads/20240907/590a5bb30e86dbbbe6a9172a41ba157a.png" alt="" />
		</view>
		<!-- 搜索 -->
		<view class="u-p-20 u-bg-white u-flex u-col-center" v-if="is_show">
			<view class="u-flex-1">
				<fa-search :mode="2"></fa-search>
			</view>
			<view class="u-p-l-15 u-p-r-5 u-flex u-col-center" v-if="is_order">
				<fa-orderby-select :filterList="filterList" :orderList="orderList" :multiple="true"
					@change="goOrderBy"></fa-orderby-select>
			</view>
		</view>
		<!-- 分类 -->
		<view class="u-border-top" v-if="isTab">
			<u-tabs :list="tabList" :active-color="theme.bgColor" :bar-width="tabwidth" name="title" :is-scroll="true"
				:current="current" @change="change"></u-tabs>
		</view>
		<!-- 轮播图 -->
		<view class="" v-if="is_show">
			<u-swiper :title="true" border-radius="0" height="320" :list="bannerList" @click="openPage"></u-swiper>
		</view>
		<!-- 列表 -->
		<fa-article-item :archives-list="archivesList"></fa-article-item>
		<!-- 为空 -->
		<view class="u-m-t-60 u-p-t-60" v-if="is_empty">
			<u-empty text="暂无内容展示" mode="list"></u-empty>
		</view>
		<!-- 加载更多 -->
		<view class="u-p-30" v-if="archivesList.length">
			<u-loadmore bg-color="#f4f6f8" :status="status" />
		</view>
		<!-- 回到顶部 -->
		<u-back-top :scroll-top="scrollTop" :icon-style="{ color: theme.bgColor }"
			:custom-style="{ backgroundColor: lightColor }"></u-back-top>
		<!-- 底部导航 -->
		<fa-tabbar></fa-tabbar>
	</view>
</template>

<script>
	import {
		archives
	} from '@/common/fa.mixin.js';
	export default {
		mixins: [archives],
		computed: {
			bannerList() {
				return this.vuex_config.bannerList || [];
			}
		},
		watch: {

		},
		onPageScroll(e) {
			let calc = 1 - (this.imgHeight - e.scrollTop) / this.imgHeight;
			this.opacity = calc
		},
		data() {
			return {
				imgHeight: 0,
				opacity: 0
			};
		},
		onLoad(e) {
			// #ifdef MP-WEIXIN || APP-PLUS
			// 获取状态栏和胶囊位置
			const {
				top,
				height
			} = uni.getMenuButtonBoundingClientRect()
			this.imgHeight = (top + height+10)*1.5;
			// #endif

			// #ifdef H5
			this.imgHeight = 100;
			// #endif
			
			let query = e;
			if (JSON.stringify(query) == '{}') {
				query = e;
			}
			if (query && JSON.stringify(query) != '{}') {
				this.params = query;
			} else {
				this.params = {
					channel: -1,
					model: -1
				}
			}
			this.getCategory();
			this.getArchives();
		},
		methods: {

		},
	};
</script>

<style lang="scss">
	.head_img {
		// position: fixed;
		top: 0;
		left: 0;
		width: 100%;
		transition: opacity 0.2s ease;
		/* 平滑过渡 */
	}

	page {
		background-color: #f4f6f8;
	}
</style>

uniapp中,你可以通过以下几种方式监听页面滚动高度: 1. 使用生命周期的onPageScroll方法。在普通页面中,你可以在onPageScroll方法中传入scrollTop值,并触发所有easy-loadimage组件下的滚动监听事件。具体代码如下: ```javascript onPageScroll(e) { this.scrollTop = e.scrollTop; // 传入scrollTop值 // 触发所有easy-loadimage组件下的滚动监听事件 }, ``` \[1\] 2. 使用window.onscroll事件。为了保证兼容性,你可以取三个值中的任意一个来获取滚动高度,即window.pageYOffset、document.documentElement.scrollTop和document.body.scrollTop。具体代码如下: ```javascript window.onscroll = function () { var scrollTop = window.pageYOffset || document.documentElement.scrollTop || document.body.scrollTop; // 获取滚动高度 console.log("滚动距离" + scrollTop); } ``` \[2\] 3. 使用scroll-view标签。在uniapp中,你可以使用scroll-view标签来实现滚动条,并监听滚动事件。具体代码如下: ```html <scroll-view scroll-y="true" class="scroll-Y" @scrolltoupper="upper" @scrolltolower="lower" @scroll="scroll"></scroll-view> ``` \[3\] 以上是uniapp监听页面滚动高度的几种方式,你可以根据自己的需求选择其中一种来实现。 #### 引用[.reference_title] - *1* [uniapp页面滚动监听](https://blog.csdn.net/chenrui310/article/details/128536818)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [uniapp监听页面与滚动h5监听页面滚动](https://blog.csdn.net/gcyaozuodashen/article/details/125327848)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [uniapp 小程序 监听数据渲染完毕 获取高度 滚动滚动到最底部](https://blog.csdn.net/qq_47247479/article/details/128203828)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值