微信小程序scroll-view bindscrolltoupper & bindscrolltolower打死都不响应的问题

#从web前端转小程序开发,遇到了无数坑,

在这里我要吐槽一句,腾讯没有自己的浏览器内核,改个源代码都他妈改的乱七八糟,兼容性差的要死。
#不说了,看问题

<scroll-view style="height:500px" bindscrolltoupper="onProductScrollToUpper" bindscrolltolower="onProductScrollToUpper" scroll-y scroll-with-animation>
    <view style="height:200px;">
       ....
    </view>
</scroll-view>

本以为可以正常运行的,妈的死活都不运行,百度一下,全他妈一个抄一个
最后还是自己深入研究,发现要让scroll-view 触发 bindscrolltoupper 跟 bindscrolltolower 必须满足以下条件

1:需要设置scroll-view高度,不管你是page 100% 还是咋样,没高度我怎么给你计算滚动到哪里了?
2:scroll-view 里面的内容必须超过scroll-view的高度,没超过你都想让我触发事件?

#好了,找到问题之后我们应该怎么办

<scroll-view style="height:500px" bindscrolltoupper="onProductScrollToUpper" bindscrolltolower="onProductScrollToUpper" scroll-y scroll-with-animation>
    <view style="height:200px;">
       ....
    </view>
    <view style="height:200px;">
       ....
    </view>
    <view style="height:200px;">
       ....
    </view>
    <view style="height:200px;">
       ....
    </view>
    <view style="height:200px;">
       ....
    </view>
    <view style="height:200px;">
       ....
    </view>
</scroll-view>

不滚动你来打我 ~~~ ,最后一句,转载请注明出处

  • 5
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
根据提供的引用内容,实现微信小程序scroll-view 的 scroll-into-view 无效果可能是由以下几个原因导致的: 1. scroll-into-view 属性的值与要跳转到的锚点标记的 id 属性值一致。例如,如果要跳转到一个 id 为 &quot;anchor1&quot; 的锚点标记,那么 scroll-into-view 的值应该设置为 &quot;anchor1&quot;。 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-view 的 scroll-into-view 实现锚点跳转效果: ```html &lt;scroll-view scroll-into-view=&quot;{{toView}}&quot; scroll-y=&quot;true&quot; style=&quot;height: 300px;&quot;&gt; &lt;view id=&quot;anchor1&quot;&gt;锚点1&lt;/view&gt; &lt;view id=&quot;anchor2&quot;&gt;锚点2&lt;/view&gt; &lt;view id=&quot;anchor3&quot;&gt;锚点3&lt;/view&gt; &lt;view id=&quot;anchor4&quot;&gt;锚点4&lt;/view&gt; &lt;view id=&quot;anchor5&quot;&gt;锚点5&lt;/view&gt; &lt;/scroll-view&gt; &lt;button bindtap=&quot;scrollToAnchor&quot;&gt;跳转到锚点2&lt;/button&gt; ``` ```javascript Page({ data: { toView: &#39;&#39; }, scrollToAnchor: function() { this.setData({ toView: &#39;anchor2&#39; }) } }) ``` 在上述示例中,scroll-view 组件设置了 scroll-into-view 属性为 toView 变量的值,当点击按钮时,toView 变量的值被设置为 &quot;anchor2&quot;,从而实现了跳转到锚点2的效果。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值