微信小程序顶部导航栏可滑动并选中放大

作者:编程小石头 时间:2023-08-23 18:49:59 

这篇文章主要介绍了微信小程序顶部导航栏可滑动并选中放大,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下

老规矩,先看效果图

微信小程序顶部导航栏可滑动并选中放大

可以看到我们实现了如下功能

  • 1,顶部导航栏

  • 2,可以左右滑动的导航栏

  • 3,选中条目放大

原理其实很简单,我这里把我研究后的源码发给大家吧。

wxml文件如下


<!-- 导航栏 -->
<scroll-view scroll-x class="navbar" scroll-with-animation scroll-left="{{scrollLeft}}rpx">
<view class="nav-item" wx:for="{{tabs}}" wx:key="id" bindtap="tabSelect" data-id="{{index}}">
 <view class="nav-text {{index==tabCur?'tab-on':''}}">{{item.name}}</view>
</view>
</scroll-view>

wxss文件如下


/* 导航栏布局相关 */
.navbar {
width: 100%;
 height: 90rpx;
/* 文本不换行 */
white-space: nowrap;
display: flex;
box-sizing: border-box;
border-bottom: 1rpx solid #eee;
background: #fff;
align-items: center;
/* 固定在顶部 */
position: fixed;
left: 0rpx;
top: 0rpx;
}

.nav-item {
padding-left: 25rpx;
padding-right: 25rpx;
height: 100%;
display: inline-block;
/* 普通文字大小 */
font-size: 28rpx;
}

.nav-text {
width: 100%;
height: 100%;
display: flex;
align-items: center;
justify-content: center;
letter-spacing: 4rpx;
box-sizing: border-box;
}

.tab-on {
color: #fbbd08;
/* 选中放大 */
font-size: 38rpx !important;
font-weight: 600;
border-bottom: 4rpx solid #fbbd08 !important;
}

js文件如下


// pages/test2/test2.js
Page({
data: {
 tabCur: 0, //默认选中
 tabs: [{
   name: '等待支付',
   id: 0
  },
  {
   name: '待发货',
   id: 1
  },
  {
   name: '待收货',
   id: 2
  },
  {
   name: '待签字',
   id: 3
  },
  {
   name: '待评价',
   id: 4
  },
  {
   name: '五星好评',
   id: 5
  },
  {
   name: '差评订单',
   id: 6
  },
  {
   name: '编程小石头',
   id: 8
  },
  {
   name: '小石头',
   id: 9
  }
 ]

},

//选择条目
tabSelect(e) {
 this.setData({
  tabCur: e.currentTarget.dataset.id,
  scrollLeft: (e.currentTarget.dataset.id - 2) * 200
 })
}
})

代码里注释很明白了,大家自己跟着多敲几遍就可以了。

来源:https://www.jianshu.com/p/8f67279c0c23

标签:微信,小程序,顶部,导航栏,滑动,放大
0
投稿

猜你喜欢

  • Javascript 每日测试 - 第五期 callee及function

    2008-07-10 13:22:00
  • 存储过程优缺点分析

    2012-04-13 11:39:56
  • 交互设计实用指南系列(2) –可及

    2010-01-21 12:48:00
  • Safari参考样式库之webkit

    2009-07-26 09:50:00
  • linux下mysql命令

    2011-01-04 19:42:00
  • AJAX:如何处理书签和后退按钮

    2008-03-21 18:44:00
  • asp精妙的SQL语句例子

    2008-03-04 17:42:00
  • gulp-htmlmin压缩html的gulp插件实例代码

    2023-08-06 01:20:18
  • asp 静态页面的另一种思路

    2011-04-08 10:32:00
  • Div即父容器不根据内容自适应高度的解决方法

    2010-04-23 18:19:00
  • python安装模块如何通过setup.py安装(超简单)

    2023-06-13 00:46:30
  • sqlserver 查询数据库大小的方法

    2012-08-21 10:22:10
  • 小谈MySQL字符集

    2009-02-13 13:30:00
  • 如何在SQL Server数据库中加密数据

    2008-12-18 14:27:00
  • 实例讲解Access数据库在线压缩的实现方法

    2008-11-28 14:29:00
  • 银行账号输入格式化, 支持部分浏缆器

    2007-09-26 18:27:00
  • JavaScript实现带自动提示的文本框效果代码

    2011-02-05 11:13:00
  • MySQL数据库常见的出错代码及出错信息

    2008-05-27 12:29:00
  • 三招解决SQL Server数据库权限冲突

    2009-03-16 16:58:00
  • python实现录音功能(可随时停止录音)

    2023-07-29 05:15:06
  • asp之家 网络编程 m.aspxhome.com