微信小程序实现带刻度尺滑块--滑动标尺/刻度尺(身高、体重选择器)

本文主要是介绍微信小程序实现带刻度尺滑块--滑动标尺/刻度尺(身高、体重选择器),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

 本来吧,像这种身高、体重的选择,我感觉一个数字滚轮就很不错,奈何UI给我出难题非要做一个刻度尺。

 思路

这刻度尺不就是一堆竖杠,每个竖杠直接间隔相同,并且间隔和数值匹配起来嘛。这样想实现起来就容易了,利用微信小程序scroll-view组件实现滑动效果,竖杠用for循环,我这里对身高体重的精度是直接到整数的,所以间隔每个竖杠直接间隔的数值是1,间距可以自己订。

但是。。。。。

做到一半发现还有一个刻度指针,这才是重点,要让指针指向的刻度值和数值匹配,这就需要你上边设置的刻度间隔必须准确

直接上代码

wxml:

<view class="flex-col self-center section_8 space-y-8"><view class="flex-col section_9 space-y-8"><view class="flex-row justify-evenly items-center self-center section_10"><text class="font_2">身高:</text><text class="font_4 text_6">{{basicInfo.height}}</text><text class="font_5 text_7">cm</text></view><view class=" section_11 space-y-4" style="height: 150rpx"><view class="cur"><view class="cur_val" style="margin-left: 155px;"></view></view><scroll-view scroll-x="true" scroll-left="{{heightSalNum}}" scroll-with-animation='true' catchscroll="bindscroll" throttle="{{false}}"><view style="background: white; justify-content: center; align-items: flex-start;  display: inline-flex"><view class="{{index%10 == 0 ? 'cursor_lang' : 'cursor'}}" wx:for="{{300}}" wx:key="index"><view wx:if="{{(index)%10==0}}" class="cursor_text">{{index}}</view></view></view></scroll-view></view></view>

cur是指针容器,因为我给他规定了宽度是310px,所以给他的子元素也就是指针给了一个距离左边155px,让他居中,当然你也可以用简单点的方式,比如flex

scroll-view是刻度容器,scroll-left指定起始位置,里边使用for循环做了300个刻度,没10个显示刻度值

css: 

.flex-col {display: flex;flex-direction: column;
}.flex-row {display: flex;flex-direction: row;
}.justify-evenly {justify-content: space-evenly;
}.items-center {align-items: center;
}.self-center {align-self: center;
}.section_9 {width: 310px;padding-top: 16.67rpx;background-color: #ffffff;overflow: hidden;border-top: solid 2.08rpx #d4d4d4;
}.space-y-8>view:not(:first-child),
.space-y-8>text:not(:first-child),
.space-y-8>image:not(:first-child) {margin-top: 16.67rpx;
}.section_10 {padding: 8.33rpx 0;background-color: #ffffff;overflow: hidden;width: 197.92rpx;
}.font_2 {font-size: 29.17rpx;font-family: HarmonyOS Sans SC;line-height: 27.08rpx;color: #000000e6;
}.font_4 {font-size: 37.5rpx;font-family: HarmonyOS Sans Condensed;line-height: 27.08rpx;color: #22c1b1;
}.text_6 {line-height: 28.13rpx;
}.font_5 {font-size: 33.33rpx;font-family: HarmonyOS Sans SC;line-height: 18.75rpx;color: #000000e6;
}.text_7 {line-height: 17.71rpx;
}.section_11 {background-color: #ffffff;overflow: hidden;position: relative;
}.space-y-4>view:not(:first-child),
.space-y-4>text:not(:first-child),
.space-y-4>image:not(:first-child) {margin-top: 8.33rpx;
}.cur {position: absolute;width: 310px;height: 38px;z-index: 10;display: flex; /* justify-content: center; */pointer-events:none;
}.cur_val {width: 0px;border: 0.50px #22c1b1 solid;
}.cursor {width: 10px;height: 24px;border-left: 1px #D9D9D9 solid
}.cursor_lang {width: 10px;height: 32px;border-left: 2px #D9D9D9 solid
}.cursor_text {color: #B3B3B3;font-size: 12px;font-family: HarmonyOS Sans SC;font-weight: 400;line-height: 12px;word-wrap: break-word;display: flex;justify-content: center;margin-top: 80rpx;width: 80rpx;margin-left: -40rpx;
}

js:

this.setData({heightSalNum: height * 10 - 155,
})

 这里计算其实位置:

height是你后台穿过来的身高,因为我每个刻度间隔设置的是10px并且指针的位置在距离左侧155px的位置,所以得出公式 height * 10 - 155

像这样

scroll-view的起始位置,移动距离等等都是基于像素,也就是你得到的值都是像素

 比如当我们的值是177时,scroll-view的起始位置(像素)就因该是177*10(我们设置的每个空的像素),也就是起始位置是1770px

此时得到了scroll-view的起始位置,但是由于scroll-view的起始位置参照的是元素最左侧和位于元素中间的指针位置差了155px,起始位置为1770px的时候指针位置就成了1770px + 155px,指针指向的刻度也成了(1770px + 155px)/10

所以在这我们需要从起始位置减去指针和起始位置的间距

最后就得出了上边的公式:height * 10 - 155

  //身高卡尺bindscroll: function (e) {// 移动距离let left = e.detail.scrollLeft;let curVal = Math.round((left + 155) / 10);this.setData({['basicInfo.height']: curVal})},

 道理和上边一样,上边是从值变为像素,这里需要从像素变成值。

left是移动距离(像素),移动距离的参照同样是最左边,所以对齐刻度要在这加上155,此时就是指针指定刻度在这个scrollview中的所在像素

使用这个像素除以10,得到的就是身高的值

扩展:

我的理解按这样计算每个空格间隔是10px,代表1cm,是不是没1px就代表0.1cm,那么不进行取整,保留一位小数的话,能不能得出精确到一位小数的身高?

本来想做成组件的,由于不想写了就不做了,想做的小伙伴可以试着写一下

这篇关于微信小程序实现带刻度尺滑块--滑动标尺/刻度尺(身高、体重选择器)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/455501

相关文章

基于Redis有序集合实现滑动窗口限流的步骤

《基于Redis有序集合实现滑动窗口限流的步骤》滑动窗口算法是一种基于时间窗口的限流算法,通过动态地滑动窗口,可以动态调整限流的速率,Redis有序集合可以用来实现滑动窗口限流,本文介绍基于Redis... 滑动窗口算法是一种基于时间窗口的限流算法,它将时间划分为若干个固定大小的窗口,每个窗口内记录了该时间

W外链微信推广短连接怎么做?

制作微信推广链接的难点分析 一、内容创作难度 制作微信推广链接时,首先需要创作有吸引力的内容。这不仅要求内容本身有趣、有价值,还要能够激起人们的分享欲望。对于许多企业和个人来说,尤其是那些缺乏创意和写作能力的人来说,这是制作微信推广链接的一大难点。 二、精准定位难度 微信用户群体庞大,不同用户的需求和兴趣各异。因此,制作推广链接时需要精准定位目标受众,以便更有效地吸引他们点击并分享链接

寻找身高相近的小朋友

题目描述: 小明今年升学到小学一年级,来到新班级后发现其他小朋友们身高参差不齐,然后就想基于各小朋友和自己的身高差对他们进行排序,请帮他实现排序。 输入描述: 第一行为正整数H和N,0<H<200,为小明的身高,0<N<50,为新班级其他小朋友个数。第二行为N个正整数H1-HN,分别是其他小朋友的身高,取值范围0<Hi<200(1<=i<=N),且N个正整数各不相同。 输出描述: 输出

uniapp设置微信小程序的交互反馈

链接:uni.showToast(OBJECT) | uni-app官网 (dcloud.net.cn) 设置操作成功的弹窗: title是我们弹窗提示的文字 showToast是我们在加载的时候进入就会弹出的提示。 2.设置失败的提示窗口和标签 icon:'error'是设置我们失败的logo 设置的文字上限是7个文字,如果需要设置的提示文字过长就需要设置icon并给

专题二_滑动窗口_算法专题详细总结

目录 滑动窗口,引入: 滑动窗口,本质:就是同向双指针; 1.⻓度最⼩的⼦数组(medium) 1.解析:给我们一个数组nums,要我们找出最小子数组的和==target,首先想到的就是暴力解法 1)暴力: 2)优化,滑动窗口: 1.进窗口 2.出窗口 3.更新值 2.⽆重复字符的最⻓⼦串(medium) 1)仍然是暴力解法: 2)优化: 进窗口:hash[s[rig

css选择器和xpath选择器在线转换器

具体前往:Css Selector(选择器)转Xpath在线工具

hot100刷题第1-9题,三个专题哈希,双指针,滑动窗口

求满足条件的子数组,一般是前缀和、滑动窗口,经常结合哈希表; 区间操作元素,一般是前缀和、差分数组 数组有序,更大概率会用到二分搜索 目前已经掌握一些基本套路,重零刷起leetcode hot 100, 套路题按套路来,非套路题适当参考gpt解法。 一、梦开始的地方, 两数之和 class Solution:#注意要返回的是数组下标def twoSum(self, nums: Lis

基于微信小程序与嵌入式系统的智能小车开发(详细流程)

一、项目概述 本项目旨在开发一款智能小车,结合微信小程序与嵌入式系统,提供实时图像处理与控制功能。用户可以通过微信小程序远程操控小车,并实时接收摄像头采集的图像。该项目解决了传统遥控小车在图像反馈和控制延迟方面的问题,提升了小车的智能化水平,适用于教育、科研和娱乐等多个领域。 二、系统架构 1. 系统架构设计 本项目的系统架构主要分为以下几个部分: 微信小程序:负责用户界面、控制指令的

微信小程序uniappvue3版本-控制tabbar某一个的显示与隐藏

1. 首先在pages.json中配置tabbar信息 2. 在代码根目录下添加 tabBar 代码文件 直接把微信小程序文档里面的四个文件复制到自己项目中就可以了   3. 根据自己的需求更改index.js文件 首先我这里需要判断什么时候隐藏某一个元素,需要引入接口 然后在切换tabbar时,改变tabbar当前点击的元素 import getList from '../

微信小程序(一)数据流与数据绑定

一、单向数据流和双向数据流 1、单项数据流:指的是我们先把模板写好,然后把模板和数据(数据可能来自后台)整合到一起形成HTML代码,然后把这段HTML代码插入到文档流里面 优点:数据跟踪方便,流向单一,追寻问题比较方便【主要体现:微信小程序】。 缺点:就是写起来不太方便,如果修改UI界面数据需要维护对应的model对象 2、双向数据流:值和UI是双向绑定的,大家都知道,只要UI里面的值发生