微信小程序自定义scroll-view的实例代码

 更新时间:2021年04月01日 15:19:37   作者:xianshengwen  
这篇文章主要给大家介绍了关于微信小程序自定义scroll-view的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

小程序自定义 scroll-view 滚动条

话不多说, 直接上效果图

效果图

wxml代码

 <scroll-view scroll-x 
  class="scroll-view" 
  bindscroll="bindScroll">
 <block wx:for="{{arr}}" wx:key="index">
 <view class="scroll-item">scroll-view{{index}}</view> 
 </block>
 </scroll-view>
 
 <!-- 滚动条 -->
 <view class="slide">
 <view class='slide-bar'>
 <view class="slide-action" 
  style="width:{{slideWidth}}rpx; margin-left:{{slideLeft<=1 ? 0 : slideLeft+'rpx'}};">
 </view>
 </view>
 </view>
 

wxss代码

 page{
 height: 100vh;
 background: rgb(111, 80, 65)
 }
 .scroll-view{
 display: flex;
 width: 100%;
 white-space: nowrap;
 padding-top: 20rpx;
 } 

 .scroll-item:nth-child(1){
 margin-left: 40rpx;
 } 

 .scroll-item {
 display: inline-block;
 width: 550rpx;
 height: 463rpx;
 background: rgba(199, 180, 165);
 border-radius: 20rpx;
 margin-right: 30rpx;
 color: #fff;
 } 

 .slide{
 background:rgb(111, 80, 65);
 width:100%;
 padding-top:20rpx;
 }
 .slide .slide-bar{
 width:180rpx;
 margin:0 auto;
 height: 4rpx;
 background: rgba(255,255,255,.2);
 } 

 .slide .slide-bar .slide-action{
 height:100%;
 background:#fff;
 } 

js代码

 /**
 * 页面的初始数据
 */
 data: {
 arr: 10,
 slideWidth: '',
 slideLeft: ''
 },

 /**
 * 生命周期函数--监听页面加载
 */
 onLoad: function (options) {
 // 计算比例
 this.calcRatio();
 },

 /**
 * 计算比例
 */
 calcRatio() {
 var windowWidth = wx.getSystemInfoSync().windowWidth;
 // 计算列表总长度
 var totalLength = (this.data.arr * 580) + 40;
 // 计算滑块的比例
 var slideRatio = 180 / totalLength * (750 / windowWidth);
 /**
 * 屏幕总长度 / 列表总长度 = 滑块占滚动条长度的比例
 * 滑块占滚动条长度的比例 * 滚动列表的长度 = 滑块的宽度
 */
 var sliderWidth = 750 / totalLength * 180;
 this.setData({
 slideWidth: sliderWidth,
 totalLength: totalLength,
 slideRatio: slideRatio
 })
 },

 /**
 * 监听滚动
 */
 bindScroll(e) {
 this.setData({
 slideLeft: e.detail.scrollLeft * this.data.slideRatio
 })
 },

附:scroll-view可滚动视图区域

总结

到此这篇关于微信小程序自定义scroll-view的文章就介绍到这了,更多相关微信小程序自定义scroll-view内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • JavaScript封装弹框插件的方法

    JavaScript封装弹框插件的方法

    这篇文章主要为大家详细介绍了JavaScript封装弹框插件的方法,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-08-08
  • js怎么只刷新当前页面一次

    js怎么只刷新当前页面一次

    Javascript刷新页面的几种方法:location.reload()、location.replace(location)、history.go(0)、location=location、location.assign(location)、document.execCommand('Refresh')、window.navigate(location)、document.URL=location.href,js怎么只刷新当前页面一次呢
    2023-09-09
  • javascript动画系列之模拟滚动条

    javascript动画系列之模拟滚动条

    本文主要介绍了js动画模拟滚动条的实现原理以及分享了通过滚动条实现的几个应用的实例代码:1.通过移动滚动条来实现数字的加减;2.通过拖动滚动条来实现元素尺寸的变化,以改变元素宽度为例;3.通过拖动滚动条来实现内容滚。需要的朋友一起来看下吧
    2016-12-12
  • 一文详解如何处理前端表单验证确保用户输入合法

    一文详解如何处理前端表单验证确保用户输入合法

    这篇文章主要介绍了如何处理前端表单验证确保用户输入合法的相关资料,并分享了最佳实践和常见坑点,通过合理使用这些方法,可以构建出健壮、友好的验证系统,文中给出了详细的代码示例,需要的朋友可以参考下
    2025-03-03
  • js鼠标移动时禁止选中文字

    js鼠标移动时禁止选中文字

    本文主要介绍了js鼠标移动时禁止选中文字的方法,具有很好的参考价值,下面跟着小编一起来看下吧
    2017-02-02
  • 微信小程序实现滑动侧边栏

    微信小程序实现滑动侧边栏

    这篇文章主要为大家详细介绍了微信小程序实现滑动侧边栏,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-07-07
  • uni-app学习之nvue使用教程

    uni-app学习之nvue使用教程

    uni-app可以说是目前跨端数最多的框架之一了,这篇文章主要给大家介绍了关于uni-app学习之nvue使用的相关资料,文中介绍的非常详细,需要的朋友可以参考下
    2022-11-11
  • 深入浅析JSONAPI在PHP中的应用

    深入浅析JSONAPI在PHP中的应用

    这篇文章主要介绍了深入浅析JSONAPI在PHP中的应用,需要的朋友可以参考下
    2017-12-12
  • JavaScript无操作后屏保功能的实现方法

    JavaScript无操作后屏保功能的实现方法

    今天组里的同事要写一个屏保的效果,要求鼠标无操作N秒后进入屏幕保护,滑动鼠标的时候取消屏幕保护。我真是难倒了,纠结了半天,搞定了,下面给大家分享实现代码
    2017-07-07
  • js模拟3D场景效果代码打包

    js模拟3D场景效果代码打包

    这几个demo上星期平安夜做的,感觉效果不错,就放在出来,分享给大家
    2012-01-01

最新评论