微信小程序实现导航栏和内容上下联动功能代码


Posted in Javascript onJune 29, 2020

  今日给大家分享一下如何实现导航栏(nav)和内容部分上下联动(相关代码模块我已单独整理放到github上面了,欢迎前来start)。

github地址:https://github.com/sunshime/weChatSkill

一、效果图:

微信小程序实现导航栏和内容上下联动功能代码

二、实现过程:

   主要是使用 scroll-view 实现导航栏部分,用 swiper 实现下面的内容部分,通过 swipercurrent 属性和导航栏的 index 相互对应来实现导航栏部分切换时内容部分跟随切换;通过 swiperbindchange 事件拿到当前轮播的索引,对应赋值实现导航栏随着内容切换的效果。

这里有几点是有必要注意一下的:

  • scroll-view 标签必须加上行内样式 overflow:hidden;white-space:nowrap; 否则无法实现滑动效果;
  • scroll-view 包裹的要滑动的盒子元素要让它们变成行内块级元素(display:inline-block;)进行横向排列;
  • scroll-view 包裹的需要滑动的盒子元素使用 display:flex; 是不起作用(无效)的;
  • scroll-view 包裹的需要滑动的盒子元素不能使用浮动。

三、相关代码如下:

(一)wxml

<view class="uplink">
	<scroll-view scroll-x scroll-with-animation scroll-left="{{scrollLefts}}" class="scroll-top" style="overflow:hidden;white-space:nowrap;">
		<view class="top-item {{curIndex===index?'active':''}}" wx:for="{{list}}" wx:key="index" data-index="{{index}}" bindtap="tabNav">{{item.name}}</view>
	</scroll-view>
	<swiper class="swiper" current="{{curIndex}}" bindchange="changeScroll" duration="{{duration}}">
		<swiper-item wx:for="{{list}}" wx:key="index" class="swipers-item">{{item.list}}</swiper-item>
	</swiper>
</view>

(二)wxss

.uplink {
 width: 100%;
 height: 100%;
}

.scroll-top {
 height: 100rpx;
 line-height: 100rpx;
 width: auto;
 background-color: #fff5f5;
}

.top-item {
 display: inline-block;
 width: 65px;
 text-align: center;
 font-size: 32rpx;
 color: #333;
}

.active {
 font-size: 36rpx;
 color: rgb(216, 27, 27);
}

.swiper {
 padding: 20rpx 30rpx;
 height: 100vh;
}

.swipers-item {
 font-size: 32rpx;
 color: #333;
 line-height: 60rpx;
 text-indent: 70rpx;
}

(三)js

import linkageList from '../../api/linkage'
Page({

 /**
  * 页面的初始数据
  */
 data: {
  list: linkageList,
  curIndex: 0,
  scrollLefts: 0,
  duration:300
 },
 // 导航栏滑动
 tabNav(e) {
  let index = e.target.dataset.index;
  this.setData({
   curIndex: index,
   scrollLefts: (index - 2) * 65
  })
 },
 // 内容滑动
 changeScroll(e) {
  let index = e.detail.current;
  this.setData({
   curIndex: index,
   scrollLefts: (index - 2) * 65
  })
 }
})

(四)模拟数据文件

const linkageList = [{
  name: '梨花雪',
  list: [
   '时光年轮一圈圈转着',
   '现在,他站在原地,回首望去,从前点点滴滴,琐琐碎碎',
   '猛然发现,自己已走过了这么多',
   '他想,如果再次遇到下雪天,他会毫不犹豫迎上去',
   '因为那里,有旧时光味道。他仍在怀念,仍在留恋。怀念,白雪纷扬日子。'
  ]
 }, {
  name: '冰雪消融',
  list: [
   '友情是每个人都应有的东西,而且相当的珍贵',
   '在朋友之间,难免会产生分歧,让友情结冰',
   '但我现在知道,友情上消融的冰雪是暖的。'
  ]
 },
 {
  name: '境由心造',
  list: [
   '有人安于某种生活,有人不能',
   '因此能安于自已目前处境的不妨就如此生活下去,不能的只好努力另找出路',
   '你无法断言哪里才是成功的,也无法肯定当自已到达了某一点之后,会不会快乐',
   '有些人永远不会感到满足,他的快乐只建立在不断地追求与争取的过程之中',
   '因此,他的目标不断地向远处推移。这种人的快乐可能少,但成就可能大。'
  ]
 },
 {
  name: '处世之道',
  list: [
   '有一群豪猪,就是野猪啊,身上长刺的那种野猪',
   '大家挤在一起过冬,它们老有一个困惑',
   '就是不知道大家在一起以什么样的距离最好',
   '离得稍微远一点,冬天就冷,互相借不着热气,大家就往一起凑凑',
   '结果一旦凑近了,彼此的刺都扎着对方了',
   '就又开始远离',
   '但是再远的话大家又觉得寒冷',
   '又想借助别人的温暖,就再凑,凑着凑着又受伤了',
   '然后再拉远,多少次磨合以后豪猪们终于找到了一种最最恰如其分的距离',
   '那就是在彼此不伤害的前提下,保持着群体的温暖。'
  ],
 },
 {
  name: '夏天',
  list: [
   '夏天的夜色很美,清爽的晚风哼着小曲来到了我们身边',
   '给我们送来了一丝丝凉意',
   '夜空中,星星眨着眼睛,静静地听着月亮姐姐讲故事',
   '这动听的故事,激发了星星们的想象',
   '星星们都在窃窃私语地讨论着,难道是在讨论演讲稿,到哪里发表演讲吗',
   '周围一片宁静,只有晚风在低低地吟唱',
   '月光洒向永不停息的小河,洒向盛开在夜晚的流星花,仿佛一切都活了',
   '萤火虫提着小灯笼,殷勤地照看着花儿、草儿,让他们快快长大、开花。'
  ]
 }, {
  name: '风筝',
  list: [
   '一只跌落在脚边的风筝把我拉回到现实',
   '是啊!无论风筝飞的多高、多远,但都离不开手中的丝线',
   '最后还是要回到地面。人不也一样吗',
   '长大了,成家了,但无论离开故乡多远,离开亲人多远,你的心还在故乡,还在父母亲人的身边啊!'
  ]
 }, {
  name: '春雨',
  list: ['我赤脚站到院中,踩在青石板上',
   '任雨水在我脸上流淌,我不禁抬起头望着那天空',
   '努力的想要看清春雨的样子,却怎么也看不清',
   '只听得见耳边的声音,那么清晰那么让人心情舒畅',
   '这温柔的春雨,带来他最动听的声音,击打着石台',
   '发出清脆的响声,声音透过雨帘,透进了我的心。'
  ]
 }, {
  name: '拥有',
  list: [
   '拥有诚实,就舍弃了虚伪',
   '拥有充实,就舍弃了无聊;拥有踏实,就舍弃了浮躁',
   '不论是有意的丢弃,还是意外的失去,只要曾经真实的拥有,在一些时候,大度的舍弃不也是一种境界吗',
   '在不经意所失去的, 你还可以重新去争取 ',
   '丢掉了爱心, 你可以在春天里寻觅, 丢掉了意志, 你要在冬天重新磨砺。',
   '但是丢掉了懒惰, 你却不能把它拾起 ',
   '欲望太多, 反成了累赘, 还有什么比拥有淡泊的心胸, 更能让自己充实、 满足呢? '
  ]
 }, {
  name: "信任",
  list: [
   '信任一个人有时需要许多年的时间',
   '因此,有些人甚至终其一生也没有真正信任过任何一个人',
   '倘若你只信任那些能够讨你欢心的人,那是毫无意义的',
   '倘若你信任你所见到的每一个人,那你就是一个傻瓜',
   '倘若你毫不犹疑、匆匆忙忙地去信任一个人,那你就可能也会那么快地被你所信任的那个人背弃',
   '倘若你只是出于某种肤浅的需要去信任一个人,那么旋踵而来的可能就是恼人的猜忌和背叛',
   '但倘若你迟迟不敢去信任一个值得你信任的人,那永远不能获得爱的甘甜和人间的温暖,你的一生也将会因此而黯淡无光。'
  ]
 }, {
  name: '生命',
  list: [
   '应当承认,生命就是希望',
   '应当说,卑鄙和庸俗不该得意过早,不该误认为它们已经成功地消灭了高尚和真纯',
   '伪装也同样不能持久,因为时间像一条长河在滔滔冲刷',
   '卑鄙者、奸商和俗棍不可能永远戴着教育家、诗人和战士的桂冠',
   '在他们畅行无阻的生涯尽头,他们的后人将长久地感到羞辱。'
  ]
 }, {
  name: '闲情',
  list: [
   '终日休息着,睡和醒的时间界限,便分得不清',
   '有时在中夜,觉得精神很圆满',
   '——听得疾雷杂以疏雨,每次电光穿入',
   '将窗台上的金钟花,轻淡清澈的映在窗帘上,又急速的隐抹了去',
   '而余影极分明的,印在我的脑膜上。我看见“自然”的淡墨画,这是第一次。'
  ]
 }, {
  name: '背影',
  list: [
   '我与父亲不相见已二年余了,我最不能忘记的是他的背影',
   '那年冬天,祖母死了,父亲的差使也交卸了,正是祸不单行的日子',
   '我从北京到徐州,打算跟着父亲奔丧回家',
   '到徐州见着父亲,看见满院狼藉的东西,又想起祖母,不禁簌簌地流下眼泪',
   '父亲说,“事已如此,不必难过,好在天无绝人之路!”'
  ]
 }, {
  name: '乡愁',
  list: [
   '经过多年的风雨磨砺,我们突然意识到',
   '那些曾在生命中抚慰过我们的精神驿站',
   '那些曾温暖和光明过我们的贫寒童年的火光',
   '却在不经意间,渐渐地离我们远了',
   '模糊了——譬如母亲、譬如童年的老屋、隔壁家羊角辫摇摇摆摆的阿娇一种难以驱遣的巨大空虚和孤寂袭来',
   '泪水顿时涌上来。这时,我们患了一种蔓延了几个世纪的病——乡愁'
  ]
 }, {
  name: '天池',
  list: [
   '从第一眼瞥见天池到和她告别,我一直沉默不语',
   '我不愿用一点声音,来弹破这宁静',
   '天池一日我的心情是宁静的,这是我最珍爱的心境',
   '山光湖色随着日影的移动而变幻',
   '午餐后,睡了一会儿,一阵冷气袭来,就像全身浴在冰山雪水之中',
   '我悄悄起来,不愿惊醒别人,独自走到廊上',
   '再次仔细观察天池:雪峰与杉林,白与黑相映,格外分明',
   '雪山后涌起的白云给强烈阳光照得白银一样刺眼。'
  ]
 }, {
  name: '秋天',
  list: [
   '秋姑娘又来到了果园里',
   '果园里的果子成熟了,葡萄架上挂满了一串串紫里透红的大葡萄',
   '它们相互掩映着自己的身体,太阳出来了',
   '照射在葡萄上就像一颗颗透明的紫色宝石',
   '桔树上,一个个金黄色的桔子,让人看了忍不住想咬一口',
   '假如你剥开桔皮,你就可以看见一瓣瓣桔子就像一弯弯亏月时的月亮,晶莹剔透。'
  ]
 }, {
  name: '早晨',
  list: [
   '清晨的江边,没有车水马龙的喧嚣',
   '没有人声鼎沸的吵杂,也没有让人深感压抑的匆匆人群',
   '清晨的江边,有的只是垂柳的迎风飘拂',
   '有的只是枝头小鸟的婉转歌唱',
   '有的只是江风中蕴含着的淡淡的腥味',
   '清晨的江边,很静',
   '静的可以抚平内心的烦躁',
   '清晨的江边,很美,绿树红花、微风拂面,不允许你携带任何忧伤。'
  ]
 }, {
  name: '栾树',
  list: [
   '栾树 十二月初,深圳,我在校园的青石板小路上捡到了栾树的蒴果',
   ' 栾树蒴果看上去有种似曾相识的漂亮--三瓣又薄又脆的果皮围拢成三棱形',
   '前端小心翼翼地开着口。'
  ]
 }, {
  name: '荷塘',
  list: [
   '又是一年荷塘色 初夏早上六点',
   '清亮透明的月儿还躲藏在云朵里,不忍离去',
   '校园内行人稀少,我骑着单车,晃晃悠悠的耷拉着星松的睡眼',
   '校园内景色如常,照样是绿。'
  ]
 }
]

export default linkageList;

总结

到此这篇关于微信小程序实现导航栏和内容上下联动功能的文章就介绍到这了,更多相关微信小程序导航栏和内容上下联动内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Javascript 相关文章推荐
总结Node.js中的一些错误类型
Aug 15 Javascript
自学实现angularjs依赖注入
Dec 20 Javascript
原生Aajax 和jQuery Ajax 写法个人总结
Mar 24 jQuery
AngularJS封装$http.post()实例详解
May 06 Javascript
原生js实现简单的焦点图效果实例
Dec 14 Javascript
详解Axios 如何取消已发送的请求
Oct 20 Javascript
微信小程序如何使用云开发
May 17 Javascript
jquery实现上传图片功能
Jun 29 jQuery
基于Electron实现桌面应用开发代码实例
Jul 07 Javascript
Element中Slider滑块的具体使用
Jul 29 Javascript
在Vue中使用Echarts实例图的方法实例
Oct 10 Javascript
解决vant-UI库修改样式无效的问题
Nov 03 Javascript
Vue.js中Line第三方登录api的实现代码
Jun 29 #Javascript
vue实现列表滚动的过渡动画
Jun 29 #Javascript
element跨分页操作选择详解
Jun 29 #Javascript
vue实现数字滚动效果
Jun 29 #Javascript
js实现从右往左匀速显示图片(无缝轮播)
Jun 29 #Javascript
Vue实现可移动水平时间轴
Jun 29 #Javascript
uniapp与webview之间的相互传值的实现
Jun 29 #Javascript
You might like
php中动态变量用法实例
2015/06/10 PHP
php伪静态验证码不显示的解决方案
2019/09/26 PHP
javascript innerHTML、outerHTML、innerText、outerText的区别
2008/11/24 Javascript
javascript xml为数据源的下拉框控件
2009/07/07 Javascript
javascript 面向对象编程基础:继承
2009/08/21 Javascript
javascript之bind使用介绍
2011/10/09 Javascript
JQuery简单实现锚点链接的平滑滚动
2015/05/03 Javascript
基于JavaScript实现网页倒计时自动跳转代码
2015/12/28 Javascript
JS 清除字符串数组中,重复元素的实现方法
2016/05/24 Javascript
js实现鼠标跟随运动效果
2020/08/02 Javascript
vue-router相关基础知识及工作原理
2018/03/16 Javascript
vue src动态加载请求获取图片的方法
2018/10/17 Javascript
JS学习笔记之数组去重实现方法小结
2019/05/29 Javascript
微信小程序实现日期格式化和倒计时
2020/11/01 Javascript
vue实现导航标题栏随页面滚动渐隐渐显效果
2020/03/12 Javascript
vue组件库的在线主题编辑器的实现思路
2020/04/03 Javascript
vue数据更新UI不刷新显示的解决办法
2020/08/06 Javascript
Python中for循环控制语句用法实例
2015/06/02 Python
关于numpy中np.nonzero()函数用法的详解
2017/02/07 Python
使用python 和 lint 删除项目无用资源的方法
2017/12/20 Python
解决安装tensorflow遇到无法卸载numpy 1.8.0rc1的问题
2018/06/13 Python
Python实现的括号匹配判断功能示例
2018/08/25 Python
浅谈python print(xx, flush = True) 全网最清晰的解释
2020/02/21 Python
pandas.DataFrame.drop_duplicates 用法介绍
2020/07/06 Python
美国嘻哈首饰购物网站:Hip Hop Bling
2016/12/30 全球购物
Skyscanner加拿大:全球旅行搜索平台
2018/11/19 全球购物
班组长岗位职责
2014/03/03 职场文书
文化建设工作方案
2014/05/12 职场文书
道德演讲稿
2014/05/21 职场文书
生活部的活动方案
2014/08/19 职场文书
2014年人大工作总结
2014/12/10 职场文书
个人委托书范文
2015/01/28 职场文书
企业介绍信范文
2015/01/30 职场文书
小学生交通安全寄语
2015/02/27 职场文书
采购部年度工作总结
2015/08/13 职场文书
Go 中的空白标识符下划线
2022/03/25 Golang