微信小程序自定义slider组件实现双向滑块

实现效果:
在这里插入图片描述

zy-slider标签是封装的自定义组件
我放到了资源这里地址:https://download.csdn.net/download/Axiaoheng_/86399342?spm=1001.2014.3001.5503

wxml引入

 <view class="zy-slider">
	<zy-slider id="zy-slider"
	minValue="0" 
	maxValue="0" min="0" max="100"
	bind:lowValueChange="lowValueChangeAction" 
	bind:heighValueChange="heighValueChangeAction" />
</view>
{
  "usingComponents": {
      "zy-slider": "../../component/zyslider"
  }
}
参数说明
minNumber/String slider 最小值
maxNumber/String slider 最大值
minValueNumber/String slider 左边滑块初始位置
maxValueNumber/String slider 右边滑块初始位置
bind:lowValueChangefunction 左边滑块回调 {lowValue:lowValue}
bind:heighValueChangefunction 右边滑块回调 {heighValue:heighValue}

绑定方法

lowValueChangeAction: function (e) {
  this.setData({
    low:e.detail.lowValue
  })
},
heighValueChangeAction: function (e) {
    this.setData({
      heigh: e.detail.heighValue
    })
},

刻度线需要单独去写:

<view class="numList">
        <view class="num_tem" wx:for="{{[0,1,2,3,4,5,6,7]}}"></view>
</view>

css

.zy-slider {
  position: relative;
}
.numList{
  width: 100%;
  display: flex;
  justify-content: space-between;  
    flex-wrap: nowrap;
    padding: 0 44rpx 0rpx 34rpx;
    box-sizing: border-box;
    position: relative;
    top: 40rpx;
}
.numList .num_tem{
  background: #677a94;
  width: 2rpx;
  height: 10rpx;
}
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
实现微信小程序双向滑块slider,可以使用小程序官方提供的组件`<slider>`,并结合自定义组件和数据绑定来实现。 具体实现步骤如下: 1. 在小程序页面中引入`<slider>`组件,设置min、max、step、value等属性,如下: ```html <slider min="0" max="100" step="1" value="{{sliderValue}}" bindchange="onSliderChange"></slider> ``` 其中,`sliderValue`为双向滑块的值,`onSliderChange`为滑动时的回调函数。 2. 创建自定义组件`<double-slider>`,包含两个`<slider>`组件,分别用于设置起始值和结束值,如下: ```html <view class="double-slider"> <slider min="0" max="{{maxValue}}" step="{{step}}" value="{{startValue}}" bindchange="onStartChange"></slider> <slider min="{{startValue}}" max="{{maxValue}}" step="{{step}}" value="{{endValue}}" bindchange="onEndChange"></slider> </view> ``` 其中,`maxValue`为最大值,`step`为步长,`startValue`为起始值,`endValue`为结束值,`onStartChange`和`onEndChange`分别为起始值和结束值滑动时的回调函数。 3. 在页面中引入自定义组件`<double-slider>`,并设置相应的属性和绑定数据,如下: ```html <double-slider maxValue="100" step="1" startValue="{{startValue}}" endValue="{{endValue}}" onStartChange="onSliderChange" onEndChange="onSliderChange"></double-slider> ``` 其中,`maxValue`和`step`为自定义组件的属性,`startValue`和`endValue`为双向滑块的值,`onStartChange`和`onEndChange`为双向滑块滑动时的回调函数。 4. 在页面的js文件中,定义相应的函数来处理滑块滑动时的操作,如下: ```javascript Page({ data: { startValue: 0, endValue: 100 }, onSliderChange: function (e) { let value = e.detail.value; this.setData({ startValue: value[0], endValue: value[1] }); }, onStartChange: function (e) { let value = e.detail.value; this.setData({ startValue: value }); }, onEndChange: function (e) { let value = e.detail.value; this.setData({ endValue: value }); } }) ``` 其中,`onSliderChange`函数处理双向滑块滑动时的操作,将起始值和结束值保存在`startValue`和`endValue`中;`onStartChange`函数处理起始值滑动时的操作,将起始值保存在`startValue`中;`onEndChange`函数处理结束值滑动时的操作,将结束值保存在`endValue`中。 这样,就可以实现微信小程序双向滑块slider了。
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值