微信小程序 scroll-view 组件中 scroll-into-view属性

小程序中如何使用 scroll-into-view 滚动到对应位置

上需求,需求很常见,如下图 (电商网站很常见),在pc端或者h5中就是一个锚点,当点击对应标题时,页面滚动到对应位置,注意不是选项卡效果。。。。。是页面滚动

在这里插入图片描述
在这里插入图片描述
如果不能理解,可随便打开一个电商网站的商品详情页可明白

**由于在小程序中,不能使用锚点,同时获取元素高度也挺麻烦的,这里采用 scroll-view 组件的 scroll-into-view属性,来实现 **

在这里插入图片描述

文档可发现,我们需要设置 对应区域的id 即可完成 滚动到对应位置

这里要注意一个问题,也是写此篇博客的目地,由于是 滚动到对应区域 可能有时会踩坑 情况如下

假设 页面高度 600px

导航是 100px(由于是当页面滚动一定距离时候才出现,所以采用了定位做法,固定在顶部)

scroll-view----->高度 100%

此时,直接使用 scroll-into-view 滚动到对应div区域,会发现 部分被导航栏遮住,而我们需要的是下图结果

在这里插入图片描述

如图 刚好在 导航下方

这是由于 scroll-view----->高度 100%,且导航采用了定位,脱离文档流,滚动到对应视图区域时,自然就到达了顶部

此时,我们可以 采用计算高度 + 定位

列表区域,高度 为 100-距离顶部
<view class="" style="height:calc(100% - 62px);position: fixed;left: 0;bottom: 0;">
			设置一个空div 高度为导航高度,动态控制----scroll-view往下挤一个导航高度
			<view :style="{height:'88rpx',display: viewId == 0 ? 'block' : 'none'}"></view>
			<scroll-view style="height: 100%;" :scroll-into-view="toView" :scroll-y="true" @scroll="pageScroll"
			 :scroll-with-animation="true">
				<view class="ditail">

这个方法不太好,但是目前也想不出来其他的

  • 5
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
根据提供的引用内容,实现微信小程序 scroll-viewscroll-into-view 无效果可能是由以下几个原因导致的: 1. scroll-into-view 属性的值与要跳转到的锚点标记的 id 属性值一致。例如,如果要跳转到一个 id 为 "anchor1" 的锚点标记,那么 scroll-into-view 的值应该设置为 "anchor1"。 2. scroll-view 容器高度不足:如果 scroll-view 容器的高度不足以显示要跳转到的锚点标记,那么 scroll-into-view 将无法生效。确保 scroll-view 容器的高度足够大,以容纳所有的内容和要跳转到的锚点标记。 3. scroll-into-view 设置在子组件上:scroll-into-view 属性应该设置在 scroll-view 组件上,而不是其子组件上。确保 scroll-into-view 属性被正确地设置在 scroll-view 组件上。 4. scroll-into-view 设置在动态生成的内容上:如果要跳转到的锚点标记是在动态生成的内容,那么需要在动态生成内容之后再设置 scroll-into-view 属性。因为 scroll-into-view 属性需要等待内容渲染完成后才能生效。 5. scroll-into-view 设置在隐藏的内容上:如果要跳转到的锚点标记是在初始状态下是隐藏的内容,那么需要在显示该内容后再设置 scroll-into-view 属性。因为 scroll-into-view 属性需要等待内容显示后才能生效。 以下是一个示例代码,演示了如何在微信小程序使用 scroll-viewscroll-into-view 实现锚点跳转效果: ```html <scroll-view scroll-into-view="{{toView}}" scroll-y="true" style="height: 300px;"> <view id="anchor1">锚点1</view> <view id="anchor2">锚点2</view> <view id="anchor3">锚点3</view> <view id="anchor4">锚点4</view> <view id="anchor5">锚点5</view> </scroll-view> <button bindtap="scrollToAnchor">跳转到锚点2</button> ``` ```javascript Page({ data: { toView: '' }, scrollToAnchor: function() { this.setData({ toView: 'anchor2' }) } }) ``` 在上述示例scroll-view 组件设置了 scroll-into-view 属性为 toView 变量的值,当点击按钮时,toView 变量的值被设置为 "anchor2",从而实现了跳转到锚点2的效果。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值