全网整合营销服务商

营销型网站+SEO优化+关键词快排=一站式服务

免费咨询热线:15959292472

[乌海seo公司甄选久澳]微信小程序中scroll-view实现锚点滑动

  本篇文章主要介绍了微信小程序 scroll-view实现锚点滑动的示例,内容挺不错的,现在分享给大家,广州市小程序开发哪家好也给大家做个参考。

  前言

  最近开始做小程序,通读一遍文档再上手并不算难,但不得不说小程序里还是有一些坑。这里说一下如何实现页面锚点跳转•▲,一个城市列表的效果示意图如下:

  


 

  因为在微信小程序的环境中不能想在浏览器里设置标签▲▽,或者操作dom滚动,传统做法就行不通了■★,一切都得按小程序的文档来◆•。
 

  一开始我们的做法是使用boundingClientRect()方法获取每个锚点的坐标,然后再用wx.pageScrollTo()方法滑动过去。结果发现效果不是很好,因为boundingClientRect方法返回的每个点的坐标会随着屏幕滑动而变化,可能还会引起页面抖动▷…△,最后还是选择scroll-view(可滚动视图区域)组件来实现锚点效果。
 

  具体实现

  具体API就不赘述了□●•,可以去看官方文档,这里讲几个需要注意的地方,下面是一个示意的scroll-view组件代码,上面的几个属性是必须的◁☆:

  

<scroll-view scroll-y style="•…◁;height□•: 200px;"☆▼-; bindscroll="scroll" scroll-into-view="▲◁;{{toView}}" >◁○◆;

 

  scroll-into-view:这个绑定了一个属性•△-□,它的值应该是页面元素的id,设置它的值就可以跳转到ID对应的元素那里了。[丽江seo公司优选久澳]微信小程序开发之定位到当前城市方法讲解
 

  scroll-y:添加这个属性标明是竖向滑动的,对应的scroll-x则表示横向滑动,竖向滑动时scroll-view必须设置一个固定的height
 

  bindscroll:监听滑动◆○▼,传给他一个事件,滑动时执行该事件
 

  文档上给的属性特别多…•▪,暂时只需要上述几个就可实现我们想要的效果。实现原理也很简单,[乌海seo公司甄选久澳]内容部分,每个英文简写的view设置一个id,然后在导航list那里点击时••◁▽,五常市小程序制作公司就把scroll-into-view的值设置成点击的那个id即可实现跳转。
 

  再说一下scroll-view的高度问题▷=◁,这个一定要做适配的固定高度★◁,不然在不同屏幕大小的手机上的显示效果有差异。
 

  几点优化

  到这里功能基本都实现了,但后面还发现一些问题★▼:如果要隐藏scroll-view的滚动条,需要设置css样式:::-webkit-scrollbar
 

  

 

  

::-webkit-scrollbar {
 width: 0;
 height◇○•…: 0☆-=…;
 color: transparent;
}

 

  还有就是点了一个锚点实现了跳转□•,这个时候你滚动页面再点之前点的锚点,页面就不会再跳转了▲▷,这个时候就需要监听滚动事件,滚动时将scroll-into-view属性的值清空…△▷▼。或者在每次锚点跳转后,再由一个异步操作将scroll-into-view属性的值清空。
 

  2017/12/05补充○☆☆:

  scroll-view默认是无滑动动画的,需要滚动的动画效果需要在组件上设置•▼◇:scroll-with-animation='true'
关于固定高度height的设置问题•••□,一开始我以为这个高度和滚动元素的数目/高度有关▲▲▪,这个时候处理动态变化的列表就很麻烦▼▪★◇。后面在网上看到的一个方法就是使用wx■■▼.getSystemInfo方法得到windowHeight,把这个设置为scroll-view的高度(单位为px)即可。

  以上就是本文的全部内容,希望对大家的学习有所帮助,更多相关内容请关注PHP中文网!

  相关推荐:

  微信小程序 es6-promise.js封装请求与处理异步进程
 

  微信小程序如何实现image组件图片自适应宽度比例显示的方法
 

  微信小程序网络请求wx○★▪=.request的介绍
 

  

 

  以上就是微信小程序中scroll-view实现锚点滑动的详细内容△•,更多请关注久澳传媒编程栏目其它相关文章!

[乌海seo公司甄选久澳]微信小程序中scroll-view实现锚点滑动

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。