<view class="movie-container">
<!-- 导航栏 -->
<view >
<scroll-view scroll-x="true" class="navbar" scroll-left="{{navScrollLeft}}" scroll-with-animation="{{true}}">
<block wx:for="{{navbarTitle}}" wx:key="index">
<view class="navbar-item {{navbarActiveIndex == index? 'navbar-item-active' : ''}}" data-navbar-index="{{index}}" catchtap="onNavBarTap">
<text>{{item}}</text>
</view>
</block>
</scroll-view>
</view>
<!-- swiper-item -->
<view class="movie-content-wrapper">
<swiper current="{{navbarActiveIndex}}" bindanimationfinish="onBindAnimationFinish">
<swiper-item wx:for="{{navbarTitle1}}" wx:for-item="item" wx:key="{{item.id}}" >
<scroll-view scroll-y="{{true}}">
<view wx:for="{{item.navbarTitle2}}" wx:for-item="items" wx:key="{{items.id}}">
{{items.name}}
</view>
</scroll-view>
</swiper-item>
</swiper>
</view>
</view>
.movie-container{
display: flex;
flex-direction: column;
}
.navbar{
display: flex;
position: absolute;
left:;
top:;
z-index:;
width: 100%;
height: 120rpx;
flex-direction: row;
text-align: center;
color: #A8A8A8;
font-size: 15px;
box-sizing: border-box;
background-color: #FFF; overflow: hidden;
line-height: 80rpx;
white-space: nowrap; }
.navbar-item{
width: 25%;
display: inline-block;
text-align: center;
padding: 26rpx 0px;
height:60rpx;
}
.navbar-item-active{
transition: all 0.3s;
border-bottom: 6rpx solid #3aadd9;
color: #3aadd9;
} .movie-content-wrapper{
padding-top: 150rpx;
}
Page({

  /**
* 页面的初始数据
*/
data: {
navbarActiveIndex: 0,
navScrollLeft: 0,
navbarTitle: [
"1",
"2",
"3",
"4",
"5",
"6",
"7"
],
navbarTitle1: [
{ id: 0, navbarTitle2: [{ id: 0, name: "1" }, { id: 1, name: "2" },]},
{ id: 1, navbarTitle2: [{ id: 0, name: "3" }, { id: 1, name: "33" },] },
{ id: 2, navbarTitle2: [{ id: 0, name: "4" }, { id: 1, name: "44" },] },
{ id: 3, navbarTitle2: [{ id: 0, name: "5" }, { id: 1, name: "55" },] },
{ id: 4, navbarTitle2: [{ id: 0, name: "6" }, { id: 1, name: "66" },] },
{ id: 5, navbarTitle2: [{ id: 0, name: "7" }, { id: 1, name: "77" },] }, ]
},
onLoad: function() {
wx.getSystemInfo({
success: (res) => {
this.setData({
pixelRatio: res.pixelRatio,
windowHeight: res.windowHeight,
windowWidth: res.windowWidth
})
},
})
},
/**
* 点击导航栏
*/
onNavBarTap: function(event) {
// 获取点击的navbar的index
let navbarTapIndex = event.currentTarget.dataset.navbarIndex
// 设置data属性中的navbarActiveIndex为当前点击的navbar
var singleNavWidth = this.data.windowWidth / 5;
//tab选项居中
this.setData({
navScrollLeft: (navbarTapIndex - 2) * singleNavWidth
})
if (this.data.navbarActiveIndex == navbarTapIndex) {
return false;
} else {
this.setData({
navbarActiveIndex: navbarTapIndex
})
}
// this.setData({
// navbarActiveIndex: navbarTapIndex
// })
}, /**
*
*/
onBindAnimationFinish: function({
detail
}) {
// 设置data属性中的navbarActiveIndex为当前点击的navbar
let navbarTapIndex = detail.current;
var singleNavWidth = this.data.windowWidth / 5;
//tab选项居中
this.setData({
navScrollLeft: (navbarTapIndex - 2) * singleNavWidth
})
if (this.data.navbarActiveIndex == navbarTapIndex) {
return false;
} else {
this.setData({
navbarActiveIndex: detail.current
})
} }
})

其实是参考网上诸位大神的一些代码自己通过修改而来的,能够从别人的代码进行修改以及学习变成自己所收获的一些知识也是本人的荣幸,很感谢百度博客的一些分享!!

微信小程序之自定义导航栏(可实现动态添加)以及swiper(swiper-item)实现自动切换,导航标题也跟着切换的更多相关文章

  1. 微信小程序 修改(自定义) 单选/复选按钮样式 checkbox/radio样式自定义

    参考文章: 微信小程序 修改(自定义) 单选/复选按钮样式 checkbox/radio样式自定义

  2. 微信小程序中自定义modal

    微信小程序中自定义modal .wxml <modal hidden="{{hidden}}" title="这里是title" confirm-text ...

  3. 微信小程序:自定义组件

    为什么要学习自定义组件? 1.用上我自己的单词abc,我希望在页面中展示椭圆形的图片, 2.打开手机淘宝,假如现在要做一个企业级项目,里面有很多页面,首页存在导航模块,点击天猫,进入第二个页面,而第二 ...

  4. 微信小程序之自定义toast弹窗

    微信小程序里面的自带弹窗icon只有两种,success和loading.有时候用户输入错误的时候想加入一个提醒图标,也可以使用wx.showToast中的image来添加图片达到使用自定义图标的目的 ...

  5. 微信小程序之自定义select下拉选项框组件

    知识点:组件,animation,获取当前点击元素的索引与内容 微信小程序中没有select下拉选项框,所以只有自定义.自定义的话,可以选择模板的方式,也可以选择组件的方式来创建. 这次我选择了组件, ...

  6. 【微信小程序】自定义模态框实例

    原文链接:https://mp.weixin.qq.com/s/23wPVFUGY-lsTiQBtUdhXA 1 概述 由于官方API提供的显示模态弹窗,只能简单地显示文字内容,不能对对话框内容进行自 ...

  7. 微信小程序实现左侧滑栏

    前言 一直想给项目中的小程序设置侧滑栏,将退出按钮放到侧滑中,但是小程序没有提供相应的控件和API,因此只能自己手动实现,网上很多大神造的轮子很不错,本文就在是站在巨人的肩膀上实现. 效果 先看看效果 ...

  8. 微信小程序之自定义组件

    在微信小程序项目中 肯定会存在很多功能和样式上相似的部分 面对这种情况 只是单单的ctrl+c ctrl+v 就显得很low了,而且也不便于后期维护那么这时候 使用微信小程序中的自定义组件功能就很合适 ...

  9. 微信小程序之自定义组件的应用

    小程序支持自定义组件,下面是一个简单的购物车组件,实现的效果如图: 效果图 创建组件 在根目录创建components目录,然后创建计数组件 count 如图: 组件内容 <!--compone ...

  10. 【微信】微信小程序 应用内的页面跳转在添加了tab以后就跳转不成功的问题解决

    在微信小程序中,本来应用页面内绑定在按钮上跳转页面可以成功,但是将页面添加在tab以后就不能实现跳转了 原本代码如下: //事件处理函数 bindViewTap: function() { wx.na ...

随机推荐

  1. Yarn (转自之乎者也)

    作者:青俞链接:https://www.zhihu.com/question/34016617/answer/57822812来源:知乎著作权归作者所有.商业转载请联系作者获得授权,非商业转载请注明出 ...

  2. 关于Java的i++和++i的区别

    之前对于 i++ 和 ++i 的理解就是: int i=1,a=0; 1.i++ 先运算在赋值,例如 a=i++,先运算a=i,后运算i=i+1,所以结果是a==1 2.++i 先赋值在运算,例如 a ...

  3. linux ssh tunnel

    ssh -qTfnN -D 7070 ape@192.168.1.35

  4. 洛谷 P3605 [USACO17JAN]Promotion Counting晋升者计数

    题目描述 The cows have once again tried to form a startup company, failing to remember from past experie ...

  5. windbg命令行选项

    我们不仅可以通过GUI的方式使用Windbg,还可以通过命令行的方式使用它,且在有些需求和使用场景下,只能使用命令行模式  windbg命令行使用以下语法: windbg [ -server Serv ...

  6. rep stos dword ptr es:[edi]

    本文链接:https://blog.csdn.net/ypist/article/details/8467163今天读代码时,忽然跳出如下一条指令==>>汇编代码: rep stos dw ...

  7. NVIDIA vGPU License服务器搭建详解

    当配置有vGPU虚拟机发起License授权请求,授权服务器会根据License中所包含的GRID License版本,加载不同的vGPU驱动(普通驱动和专业Quodra卡驱动).目前vPC和vApp ...

  8. ARC093F Dark Horse 【容斥,状压dp】

    题目链接:gfoj 神仙计数题. 可以转化为求\(p_1,p_2,\ldots,p_{2^n}\),使得\(b_i=\min\limits_{j=2^i+1}^{2^{i+1}}p_j\)都不属于\( ...

  9. RESTFull开发风格

  10. Kubernetes Pod概述

    Pod简介 Pod是Kubernetes创建或部署的最小/最简单的基本单位,一个Pod代表集群上正在运行的一个进程. 一个Pod封装一个应用容器,Pod代表部署的一个单位. Pods提供两种共享资源: ...