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


Posted in Javascript onDecember 05, 2019

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

老规矩,先看效果图

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

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

  • 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
  })
 }
})

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

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
js监听表单value的修改同步问题,跨浏览器支持
Dec 31 Javascript
网站繁简切换的JS遇到页面卡死的解决方法
Mar 12 Javascript
浅析JQuery中的html(),text(),val()区别
Sep 01 Javascript
jQuery编程中的一些核心方法简介
Aug 14 Javascript
jquery实现图片切换代码
Oct 13 Javascript
etmvc+jQuery EasyUI+combobox多值操作实现角色授权实例
Nov 09 Javascript
微信小程序(六):列表上拉加载下拉刷新示例
Jan 13 Javascript
快速实现jQuery多级菜单效果
Feb 01 Javascript
Vue.js如何优雅的进行form validation
Apr 07 Javascript
jQuery仿移动端支付宝键盘的实现代码
Aug 15 jQuery
JS实现提示框跟随鼠标移动
Aug 27 Javascript
React Native 混合开发多入口加载方式详解
Sep 23 Javascript
微信小程序实现点击按钮后修改颜色
Dec 05 #Javascript
React 父子组件通信的实现方法
Dec 05 #Javascript
Javascript中的this,bind和that使用实例
Dec 05 #Javascript
原生JS与CSS实现软件卸载对话框功能
Dec 05 #Javascript
Vue快速实现通用表单验证功能
Dec 05 #Javascript
Vue组件通信中非父子组件传值知识点总结
Dec 05 #Javascript
基于javascript实现贪吃蛇经典小游戏
Apr 10 #Javascript
You might like
phpmyadmin config.inc.php配置示例
2013/08/27 PHP
PHP管理依赖(dependency)关系工具 Composer的自动加载(autoload)
2014/08/18 PHP
关于PHP中协程和阻塞的一些理解与思考
2017/08/11 PHP
一个高效的JavaScript压缩工具下载集合
2007/03/06 Javascript
js检测客户端不是firefox则提示下载
2007/04/07 Javascript
js tab 选项卡
2009/04/26 Javascript
JQuery 学习笔记 选择器之二
2009/07/23 Javascript
jquery实现表单输入时提示文字滑动向上效果
2015/08/10 Javascript
Jquery基础之事件操作详解
2016/06/14 Javascript
javascript中数组和字符串的方法对比
2016/07/20 Javascript
详解Angular2中的编程对象Observable
2016/09/17 Javascript
微信小程序 图片等比例缩放(图片自适应屏幕)
2016/11/16 Javascript
基于JavaScript实现Tab选项卡切换效果
2016/11/24 Javascript
详解axios在node.js中的post使用
2017/04/27 Javascript
关于JavaScript中的this指向问题总结篇
2017/07/23 Javascript
vue-自定义组件传值的实例讲解
2018/09/18 Javascript
vue富文本编辑器组件vue-quill-edit使用教程
2018/09/21 Javascript
JS计算斐波拉切代码实例
2019/09/12 Javascript
让mocha支持ES6模块的方法实现
2020/01/14 Javascript
跟老齐学Python之开始真正编程
2014/09/12 Python
Python在图片中添加文字的两种方法
2017/04/29 Python
Python subprocess模块功能与常见用法实例详解
2018/06/28 Python
Python实现TCP通信的示例代码
2019/09/09 Python
python使用 request 发送表单数据操作示例
2019/09/25 Python
python字符串判断密码强弱
2020/03/18 Python
俄罗斯花园种植材料批发和零售网上商店:Беккер
2019/07/22 全球购物
日语专业毕业生自荐信
2013/11/11 职场文书
ktv中秋节活动方案
2014/01/30 职场文书
绿化先进工作者事迹材料
2014/01/30 职场文书
成绩单家长评语大全
2014/04/16 职场文书
对照四风自我剖析材料
2014/10/07 职场文书
综治维稳工作汇报
2014/10/27 职场文书
2014年财务部工作总结
2014/11/11 职场文书
优秀教师单行材料
2014/12/16 职场文书
关于观后感的作文
2015/06/18 职场文书
进行数据处理的6个 Python 代码块分享
2022/04/06 Python