微信小程序,封装身高体重选择器组件

这篇具有很好参考价值的文章主要介绍了微信小程序,封装身高体重选择器组件。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

微信小程序,封装身高体重选择器组件,微信小程序,微信小程序,小程序,uniapp,taro

wxml代码:

// 微信小程序的插值语法不支持直接使用Math
<wxs src="./ruler.wxs" module="math"></wxs>
<view class="ruler-container">
  <scroll-view scroll-left="{{scrollLeft}}" enhanced="{{true}}" bounces="{{false}}" scroll-x="true" class="scroll-box" bindscroll="scroll">
  	// 刻度
    <view class="ruler" style="width: {{(max-min)*6+1}}px;">
      <view wx:for="{{(max-min)+1}}" wx:key="item" style="display: flex;" class="scale" style="height: {{index%5===0?'20rpx':'12rpx'}};"></view>
    </view>
    // 刻度值
    <view class="scale-value" style="width: {{(max-min)*6}}px;">
      <view class="zero">{{min}}</view>
      <view class="scale-value-item" wx:for="{{math.ceil((max-min)/10)}}" wx:key="item">{{(index+1)*10+min}}</view>
    </view>
  </scroll-view>
  <view class="value-box">
    <text>{{value}}{{unit}}</text>
    <view class="line"></view>
  </view>
</view>

scrollLeft 保证能选择到最小值和最大值
bounces 关闭ios的回弹效果,回弹之前会有显示复数和大于最大值的情况(也可以不关闭,设置例如:min = val<min?min:val)

宽度:"width: {{(max-min)*6+1}}px;"

6:间隔+刻度的宽度
+1 是额外加一个刻度,这样才完整。

高度:"height: {{index%5===0?'20rpx':'12rpx'}};"

index%5===0: 5的倍数为长刻度,否则为短刻度

wxs代码:

module.exports.ceil = function (val) {
  return Math.ceil(val);
}

wxs模块文档

ts代码:

Component({
  properties: {
    min: {
      type: Number,
      value: 0
    },
    max: {
      type: Number,
      value: 100
    },
    unit: {
      type: String,
      value: '单位'
    },
    defaultValue: {
      type: Number,
      value: 0
    },
    setvalue:Function
  },
  data: {
    value: 0,
    cache: 0,
    scrollLeft: 0
  },
  onShow() {
    const value = this.properties.defaultValue
    this.setData({
      value,
      scrollLeft: value * 6
    })
  },
  attached() {
    const { defaultValue, min } = this.properties
    setTimeout(() => {
      this.setData({
        value: defaultValue,
        scrollLeft: (defaultValue - min) * 6
      })
    }, 100);
  },
  methods: {
    scroll: function (e: WechatMiniprogram.TouchEvent) {
      const scrollLeft = e.detail.scrollLeft + 1
      let value = Math.ceil(scrollLeft / 6)
      value = value ? value - 1 : value
      if (value % 10 === 0 && Math.floor(value / 10) !== this.data.cache) {
        wx.vibrateShort({ type: 'light' })
        this.setData({
          cache: Math.floor(value / 10)
        })
      }
      this.setData({
        value: value + this.properties.min
      })
      this.triggerEvent('setvalue',value + this.properties.min)
    }
  }
})

参数:
min:刻度最小值
max:刻度最大值
unit:单位
defaultValue:初始值
setvalue:自定义方法

css代码:文章来源地址https://www.toymoban.com/news/detail-663246.html

.ruler-container {
  position: relative;
  background: #FBFBFB;
  border-radius: 8rpx;

  .value-box {
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    top: 0;
    height: 70rpx;
    z-index: 99999999;
    width: 100rpx;
    display: flex;
    flex-direction: column;
    align-items: center;
    color: #46D2A1;
    font-size: 28rpx;
    line-height: 40rpx;
    padding-top: 8rpx;

    .line {
      width: 2px;
      height: 28rpx;
      background: #46D2A1;
    }
  }
}

.scroll-box {
  height: 122rpx;
}

.ruler {
  display: flex;
  align-items: flex-end;
  margin-top: 50rpx;
  padding: 0 50%;

  .scale {
    width: 1px;
    background-color: #C2C2C2;
    margin-right: 5px;
    &:last-child{
      margin-right: 0;
    }
  }
}

.scale-value {
  display: flex;
  padding: 0 50%;
  position: relative;
  overflow: hidden;
  .scale-value-item {
    color: #C2C2C2;
    font-size: 22rpx;
    width: 60px;
    line-height: 32rpx;
    text-align: center;
    &:last-child{
      width: 30px;
      transform: translateX(50%);
    }
  }
  .zero{
    width: 30px;
    color: #C2C2C2;
    font-size: 22rpx;
    line-height: 32rpx;
    transform: translateX(-50%);
    text-align: center;
  }
}

到了这里,关于微信小程序,封装身高体重选择器组件的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 微信小程序封装组件

    在日常开发中,有页面之间有很多相似的组件,我们可以对其相似的代码块进行封装,进行复用 先在根目录下创建一个component文件夹 在里面创建一个目录wMyTop文件夹,然后右键点击Component创建一个组件输入wMyTop,回车 然后在wMyTop.json中把\\\"component\\\": true,改为true,意思就是开启

    2024年02月09日
    浏览(32)
  • 【uniapp&微信小程序】封装uni.request()

    前言         在项目开发过程中,往往需要对请求进行二次封装,这篇文章将对uni.request()进行二次封装,并实现多个环境的请求配置,对请求方式,数据格式等进行封装,将请求做到最简化。 一.封装uni.request() 第一步基于 uni.request() 进行二次封装,集成项目开发中需要的参

    2024年02月09日
    浏览(79)
  • uniapp微信小程序自定义封装分段器。

    话不多说先上效果 这里我用的是cil框架 vue3 下面贴代码 组价代码: 父组件使用方法:

    2024年02月04日
    浏览(31)
  • uniapp 微信小程序请求拦截器 接口封装

    前言: 请求拦截器可以在我们需要传递请求头的时候使用,例如:token 也会在当token发生变化的时候给予响应,所以我们做好对应的判断即可 1.首先在根目录创建common文件夹, 在里面创建request.js文件并加入以下代码: 2,在common文件夹下接着新建一个example.js文件来当作接口

    2024年01月23日
    浏览(34)
  • 微信小程序(原生)封装弹框组件

    小程序封装原生弹框组件(一个弹框,点击确定关闭弹框,有需要的直接复制哦) 上面是组件的内容,下面是引用方法 首先第一步在app.json或者单文件json文件引入 我用的比较多就在app.json引入的 下面是文件使用方法: 只需要子啊data中控制这两个属性就可以了,喜欢的点个赞

    2024年02月11日
    浏览(40)
  • uniapp 微信小程序axios库的封装及使用

    第一步:安装axios及适配器 安装依赖 需要注意使用uniapp-vue3版本时axios的版本需要0.26.0以下,建议锁版本   axios-miniprogram-adapter 这个依赖主要是适配小程序网络请求的适配器,为了解决uniapp 适配axios请求,避免报adapter is not a function错误 第二步:axios二次封装 在utils文件下新建

    2024年02月11日
    浏览(36)
  • 微信小程序使用vant时间选择器二次封装成自定义区间时间选择

    目录 1.引入vant组件库 2.wxml页面 3.js页面 1.安装vant # 通过 npm 安装 npm i @vant/weapp -S --production # 通过 yarn 安装 yarn add @vant/weapp --production # 安装 0.x 版本 npm i vant-weapp -S --production 2.将 app.json 中的  \\\"style\\\": \\\"v2\\\"  去除 3.在  project.config.json 里面的 \\\"setting\\\":{ } 里面添加下面的代码 4.构建

    2024年02月17日
    浏览(42)
  • 【微信小程序】选择器组件picker

    picker组件是一种从底部向上弹起的滚动选择器。 在官方文档中,有提供五种类型的picker组件,如普通选择器,多列选择器,时间选择器,日期选择器和省市区选择器。 (猜测是,这些选择器时不同的且常用的某种类型,于是就产生固定的模版)。 而在写法上是这么写滴,

    2024年01月18日
    浏览(41)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包