This article shares the specific code of vue uniapp to achieve the segmenter effect for your reference. The specific content is as follows This is just to record the effect of dynamically changing the style with vue Show the effect first Template <view class="countTime"> <text class="title">Discounts and dining hours</text> <view class="wrap"> <view class="box" v-for="(item,index) in discountList" :key="index" @click="toggleItem(index)"> <view class="selBox" :style="[itemStyle(index)]"> <view class="countBox"> <text class="count">{{item.count}}</text> <text>Fold</text> </view> <text class="time">{{item.time}}</text> </view> <text class="countPrice" :style="[priceStyle(index)]">After discount, average price per person is ¥100</text> </view> </view> </view> Script part The key to this part is the code under computed export default { data() { return { themColor:this.Enum.Them.base, discountList:[{ "count":6.9, "time":"12:00~13:00" },{ "count":6.7, "time":"14:00~16:00" },{ "count":6.5, "time":"20:00~22:00" }], currentIndex:0 } }, computed:{ itemStyle(){ return index => { let style = {} if(index === this.currentIndex){ style.backgroundColor = this.themColor; style.border = `1px solid ${this.themColor}`; style.color = '#fff'; } //When the second one is selected, the first right border and the third left border are set to none if(this.currentIndex === 1){ if(index === this.currentIndex - 1){ style.borderRight = 'none !important' } if(index === this.currentIndex + 1){ style.borderLeft = 'none !important' } } return style } }, priceStyle(){ return index => { let style = {} if(index === this.currentIndex){ style.color = this.themColor } return style } } }, methods: { toggleItem(idx){ this.currentIndex = idx } } } CSS Styles The scss used here will not be described in detail here. .countTime{ display: flex; flex-direction: column; .title{ font-size: $uni-font-size-bl; margin: 20rpx 0; } .wrap{ display: flex; .box{ @include flex(column,center,center); width: 33%; &:nth-child(2){ & > .selBox{ border-left: none; border-right: none; } } .selBox{ @include flex(column,center,center); width: 100%; height: 150rpx; border: 1px solid $uni-border-color; .countBox{ font-size: $uni-font-size-lg; font-weight: bold; margin-bottom: 10rpx; .count{ font-size: $uni-font-size-bl; } } .time{ font-size: $uni-font-size-l; } } .countPrice{ margin-top: 10rpx; font-size: $uni-font-size-l; } } } } The above is the full content of this article. I hope it will be helpful for everyone’s study. I also hope that everyone will support 123WORDPRESS.COM. You may also be interested in:
|
<<: MySql8 WITH RECURSIVE recursive query parent-child collection method
>>: How to modify the contents of an existing Docker container
<body style="scroll:no"> <tabl...
Preface When using the MySQL database, sometimes ...
Preface Through my previous Tomcat series of arti...
Sometimes, in order to facilitate the export and ...
Recently, when I was using C# to make a Web progra...
Table of contents 1. Introduction 2. Detailed exp...
Table of contents Preface 1. Reasons: 2. Solution...
Require The div under the body is vertically cent...
The VMware Workstation Pro version I use is: 1. F...
1. Subquery MySQL 4.1 and above support subquerie...
Environment: init_worker_by_lua, set_by_lua, rewr...
Copy code The code is as follows: <html> &l...
Pull the image docker pull season/fastdfs:1.2 Sta...
1. Windows Server 2019 Installation Install Windo...
This article shares the specific code for impleme...