uniapp刻度尺的实现(swiper)滑动打分器

实现图(百分制):滑动swiper进行打分,分数加减

html 复制代码
<view class="scoring">
	<view class="toggle">
		<view class="score">
			<text>{{'0'}}</text>
			<view class="scoreId" >
				<block v-if="transFlag&&scoreFlag">{{testScore}}</block>
				<block v-else>{{currentScore}}</block>
			</view>
			<text>{{'100'}}</text>
		</view>
		<view>
			<view class="line-con">
				<text class="line"></text>
			</view>
			<swiper class="swipers" display-multiple-items="17" duration="400"  easing-function="easeInOutCubic" @transition="transScore" @change="changeScore"  :current="currentSwiper" >
				<swiper-item class="swiperItems" v-for="(item,index) in 117" key="index">
				  <view class="lines"></view>
				</swiper-item>
			</swiper>
		</view>
	</view>
</view>
typescript 复制代码
/* 分数波动过程中显示实时分数*/ /*滑动过快会有问题*/
transScore(e){
	this.transFlag = true
	if(this.transFlag&&this.scoreFlag){
		this.testScore = this.currentScore +  Math.floor(e.detail.dx/21) <= 0? 0 :this.currentScore +  Math.floor(e.detail.dx/20)
	}else{
		this.testScore = this.currentScore
	}
},
/*打分动作回调-停下*/
changeScore(e){
	this.currentScore = this.currentSwiper===null||this.currentSwiper===''?this.currentSwiper:e.detail.current;
	this.testScore = this.currentScore
	this.currentSwiper = e.detail.current;
	this.transFlag = false;
	this.scoreFlag = false;
	setTimeout(()=>{
		this.scoreFlag = true
	},600)
},
css 复制代码
.toggle{
	background-image: url(/static/image/toggle.png);
	background-size: cover;
	padding: 4px 4px 16px 4px;
	border-radius: 8px;
	box-shadow: 2px 6px 8px 0 #00622D17;
	margin-top: 16px;
	border-right: 1px solid #fbfcfdc2;
}
.score{
	display: flex;
	justify-content: space-between;
	color: #BDBDBD;
	font-size: 24rpx;
	align-items: flex-end;
	font-weight: bold;
	position: relative;
	height: 70rpx;
	margin-top: 22rpx;
	padding: 0 10px;
	.scoreId{
		color: #20A13E;
		font-size:64rpx ;
		position: absolute;
		text-align: center;
		width: 100%;
		bottom: 0px;
		left: 0;
	}
}
.swipers{
  height: 100%;
  width: 100%;
  margin: 0 auto;
  overflow: visible;
  height: 100rpx;
}
.swiperItems{
  font-size:24rpx;
  position:relative;
  margin-top: 32rpx;
  height: 56rpx !important;
  overflow: visible;
  display: flex;
  align-items: center;
  justify-content: center;
}
.swiperItems > .lines{
  background-color:#BDBDBD;
  width:1px;
  height:58rpx !important;
}
.line-con{
	width: 100%;
	position: relative;
	display: flex;
	justify-content: center;
	align-items: center;
	.line{
	  position: absolute;
	  width: 6rpx;
	  height: 40px;
	  top: 20rpx;
	  background: #20a13e;
	  z-index: 6;
	}
}
相关推荐
homelook10 小时前
uniapp蓝牙demo
uni-app
2501_915909061 天前
手机崩溃日志导出的工程化体系,从系统级诊断到应用行为分析的多工具协同方法
android·ios·智能手机·小程序·uni-app·iphone·webview
郑州光合科技余经理1 天前
技术视角:海外版一站式同城生活服务平台源码解析
java·开发语言·uni-app·php·排序算法·objective-c·生活
wangdaoyin20101 天前
UniApp中使用LivePlayer进行视频或在流媒体播放
uni-app·liveplayer·h5播放视频
2501_915106321 天前
App HTTPS 抓包实战解析,从代理调试到真实网络流量观察的完整抓包思路
网络协议·http·ios·小程序·https·uni-app·iphone
游戏开发爱好者81 天前
苹果App Store应用程序上架方式全面指南
android·小程序·https·uni-app·iphone·webview
2501_916008891 天前
深入理解 iPhone 文件管理,从沙盒结构到开发调试的多工具协同实践
android·ios·小程序·https·uni-app·iphone·webview
一室易安1 天前
解决使用 UniApp 搭配 Vue3 小程序开始 使用uview-plus 的返回顶部up-back-top中onPageScroll 不触发的问题
小程序·uni-app
yilan_n1 天前
鸿蒙应用上传
vue.js·华为·uni-app
yilan_n1 天前
【UniApp实战】手撸面包屑导航与路由管理 (拒绝页面闪烁)
前端·javascript·vue.js·uni-app·gitcode