微信小程序导航栏跟随滑动效果的实现代码


Posted in Javascript onMay 14, 2019

效果图

微信小程序导航栏跟随滑动效果的实现代码

.wxml

<view class='tabBar'>
<view class='tabItem wx:if="{{tabClick===0?"click":""}}"' bindtap='clickTab' data-index='0'>tab1</view>
<view class='tabItem wx:if="{{tabClick===1?"click":""}}"' bindtap='clickTab' data-index='1'>tab2 </view>
<view class='tabItem wx:if="{{tabClick===2?"click":""}}"' bindtap='clickTab' data-index='2'>tab3 </view>
<view class='underline' animation="{{animationData}}" style='left:{{isLeft}}'></view>
</view>

.wxss

.tabBar{
height: 80rpx;
background-color:#50B7EA;
width: 100%;
font-size: 28rpx;
color: rgba(255,255,255,0.50);
position: fixed;
top: 0;
left: 0;
display: flex;
justify-content: center;
align-items: center;
z-index: 997;
}
.tabItem{
width: 33.333%;
display: flex;
align-content: center;
justify-content: center;
position: relative;
height: 100%;
font-size: 28rpx;
}
.click{
color: white;
}
.underline{
position: absolute;
content: '';
width: 84rpx;
height: 3px;
background-color:white;
bottom: 0;
}

.js

data:{
tabClick: 0,
animationData: {},
 isLeft: '12%'
},
swiperTab: function (e) {
var that = this;
var index = e.detail.current
console.log(e.detail.current)
var animation = wx.createAnimation({
duration: 1000,
timingFunction: "ease",
})
this.animation = animation
if (index === 0) {
animation.translate(0, 0).step();
that.setData({
animationData: animation.export()
})
that.setData({
tabClick: e.detail.current
});
} else if (index === 1) {
var w = wx.getSystemInfoSync().windowWidth;
w = w * 0.32
animation.translate(w, 0).step();
that.setData({
animationData: animation.export()
})
that.setData({
tabClick: e.detail.current
});
} else if(index === 2){
var w = wx.getSystemInfoSync().windowWidth;
w = w * 0.65
animation.translate(w, 0).step();
that.setData({
animationData: animation.export()
})
that.setData({
tabClick: e.detail.current
});
}
},

总结 

以上所述是小编给大家介绍的微信小程序导航栏跟随滑动效果的实现代码,希望对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会及时回复大家的!

Javascript 相关文章推荐
jQuery图片播放8款精美插件分享
Feb 17 Javascript
使用Js让Html中特殊字符不被转义
Nov 05 Javascript
网页运行时提示对象不支持abigimage属性或方法
Aug 10 Javascript
简单讲解jQuery中的子元素过滤选择器
Apr 18 Javascript
利用jQuery实现打字机字幕效果实例代码
Sep 02 Javascript
jQuery实现的购物车物品数量加减功能代码
Nov 16 Javascript
Express框架之connect-flash详解
May 31 Javascript
vue 配置多页面应用的示例代码
Oct 22 Javascript
说说如何在Vue.js中实现数字输入组件的方法
Jan 08 Javascript
基于vue如何发布一个npm包的方法步骤
May 15 Javascript
vue2.0 获取从http接口中获取数据,组件开发,路由配置方式
Nov 04 Javascript
js实现筛选功能
Nov 24 Javascript
详解VSCode配置启动Vue项目
May 14 #Javascript
微信小程序下拉菜单效果的实例代码
May 14 #Javascript
jquery+css实现Tab栏切换的代码实例
May 14 #jQuery
jquery实现二级导航下拉菜单效果实例
May 14 #jQuery
js纯前端实现腾讯cos文件上传功能的示例代码
May 14 #Javascript
解决 viewer.js 动态更新图片导致无法预览的问题
May 14 #Javascript
vue如何获取自定义元素属性参数值的方法
May 14 #Javascript
You might like
如何获得PHP相关资料
2006/10/09 PHP
CodeIgniter基本配置详细介绍
2013/11/12 PHP
php并发加锁示例
2016/10/17 PHP
laravel 5.4中实现无限级分类的方法示例
2017/07/27 PHP
PHP 7.4 新语法之箭头函数实例详解
2019/05/09 PHP
jquery构造器的实现代码小结
2011/05/16 Javascript
jQuery操作select的实例代码
2012/06/14 Javascript
jQuery CSS3相结合实现时钟插件
2016/01/08 Javascript
javascript拖拽应用实例(二)
2016/03/25 Javascript
jQuery之简单的表单验证实例
2016/07/07 Javascript
jQuery Pagination分页插件使用方法详解
2017/02/28 Javascript
Angular使用$http.jsonp发送跨站请求的方法
2017/03/16 Javascript
利用jquery去掉时光轴头尾部线条的方法实例
2017/06/16 jQuery
vue 组件中slot插口的具体用法
2018/04/03 Javascript
基于Nodejs的Tcp封包和解包的理解
2018/09/19 NodeJs
Vue.js轮播图走马灯代码实例(全)
2019/05/08 Javascript
es6函数之尾调用优化实例分析
2020/04/25 Javascript
vscode 插件开发 + vue的操作方法
2020/06/05 Javascript
vue 使用饿了么UI仿写teambition的筛选功能
2021/03/01 Vue.js
python学习笔记--将python源文件打包成exe文件(pyinstaller)
2018/05/26 Python
Python3 pip3 list 出现 DEPRECATION 警告的解决方法
2019/02/16 Python
python下的opencv画矩形和文字注释的实现方法
2019/07/09 Python
Python 通过正则表达式快速获取电影的下载地址
2020/08/17 Python
浅析python函数式编程
2020/09/26 Python
CSS3中border-radius属性设定圆角的使用技巧
2016/05/10 HTML / CSS
HTML5开发动态音频图的实现
2020/07/02 HTML / CSS
流行文化收藏品:Sideshow(DC漫画,星球大战,漫威)
2019/03/17 全球购物
护理不良事件检讨书
2014/02/06 职场文书
《雾凇》教学反思
2014/02/17 职场文书
房产转让协议书
2014/04/11 职场文书
2019年最新七夕唯美祝福语(60条)
2019/07/22 职场文书
Oracle 数据仓库ETL技术之多表插入语句的示例详解
2021/04/12 Oracle
Python通过m3u8文件下载合并ts视频的操作
2021/04/16 Python
MySQL 重命名表的操作方法及注意事项
2021/05/21 MySQL
MySQL 发生同步延迟时Seconds_Behind_Master还为0的原因
2021/06/21 MySQL
Sentry的安装、配置、使用教程(Sentry日志手机系统)
2022/07/23 Python