【小程序】实现顶部选中效果

一、效果演示

在这里插入图片描述

二、功能代码

1.设计思路

1.首先设计完大体框架:
在这里插入图片描述
全部、待支付、待发货、已发货、交易成功这五个部分都是单独的view分开来装的,在大的view中有设置了下边框

2.选中的时候通过给选中的view修改样式来实现一个选中效果,需要用js来实现样式的改变

2.相关代码

1.Html代码

<view class="topView" style="position:fixed;top:49px;left:0;z-index:200">
  <block wx:for="{{statusList}}" wx:key="id">
    <view id="{{item.id}}" class="{{item.id == isChecked ? 'active':''}} topChild" bindtap="choiceStatus">{{item.statusName}}</view>
 </block>
</view>

2.CSS代码

.topView{
  width:100%;
  height:48px;
  display:flex;
  background-color: #ffffff;
  border-bottom:1px solid #e2e1e1;
}
.topChild{
  width:20%;
  height:48px;
  text-align: center;
  line-height: 3.4;
  font-size:14px;
  color:#333333;
}
/*点击时按钮状态*/
.active{
  color:#2dbef8;
  border-bottom:2px solid #2dbef8;
}

3.JS代码

Page({
 
  data: {
    statusList: [{//顶部状态按钮
      "statusName": "全部",
      "id": "all"
    },
    {
      "statusName": "待支付",
      "id": "draft"
    },
    {
      "statusName": "待发货",
      "id": "waitSolve"
    },
    {
      "statusName": "已发货",
      "id": "doingSolve"
    },
    {
      "statusName": "交易成功",
      "id": "doneSolve"
    },
    ],
    isChecked: 0 //判断是否选中
  },
  
  //绑定顶部状态切换的点击事件
  choiceStatus: function (e) {
    var that = this;
    var code = e.currentTarget.id;
    that.setData({
      isChecked: code
    })
  },
  
})

3.涉及到的其它知识

1.view的多样式

大家直接看class后面的部分,可以看见class后面不止一个样式类

 <view id="{{item.id}}" class="{{item.id == isChecked ? 'active':''}} topChild" 
 bindtap="choiceStatus">{{item.statusName}}</view>

小结:
1.class中可以包含多个样式,多个样式之间用空格隔开
2. ‘’代表的是空样式

2.wx:key

如果列表中项目的位置会动态改变或者有新的项目添加到列表中,并且希望列表中的项目保持自己的特征和状态(如 input 中的输入内容,switch 的选中状态),需要使用 wx:key 来指定列表中项目的唯一的标识符。

比如当前switch是选中状态,如果没有设置wx:key,状态可能会发生改变,所以设置wx:key可以用来保持自己的特征和状态,并且在下次渲染时不会重新创建,提高了列表渲染时的效率。

详细的wx:key参考博客
点我跳转

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值