位置: IT常识 - 正文

微信小程序实现滑动/点击切换Tab(微信小程序实现文件上传)

编辑:rootadmin
微信小程序实现滑动/点击切换Tab 背景

推荐整理分享微信小程序实现滑动/点击切换Tab(微信小程序实现文件上传),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:微信小程序实现文件上传,微信小程序实现轮播图,微信小程序实现页面跳转,微信小程序实现轮播效果的组件,微信小程序实现懒加载,微信小程序实现轮播效果的组件,微信小程序实现懒加载,微信小程序实现懒加载,内容如对您有帮助,希望把文章链接给更多的朋友!

👏 swiper+scroll-view实现滑动/点击切换Tab,以及scroll-left的使用~

🥇文末分享源代码。记得点赞+关注+收藏!

1.实现效果微信小程序实现滑动/点击切换Tab(微信小程序实现文件上传)

2.实现步骤2.1 scroll-view实现tab列表

scroll-view: 可滚动视图区域。使用竖向滚动时,需要给scroll-view一个固定高度,通过 WXSS 设置 height。组件属性的长度单位默认为px。 scroll-x(boolean):允许横向滚动 scroll-y(boolean):允许纵向滚动 scroll-left(number/string):设置横向滚动条位置 scroll-with-animation(boolean):在设置滚动条位置时使用动画过渡

定义一个tab列表,scroll-view包裹,允许横向滚动,设置scroll-left默认为0每个tab设置为display: inline-block,scroll-view设置 white-space: nowrap不换行

<scroll-view scroll-x class="container-head-sc" scroll-left="{{sleft}}" scroll-with-animation="true"> <view class="item" wx:key="list" wx:for="{{list}}" wx:for-index="index">tab-{{index+1}} </view> </scroll-view>.container-head-sc { height: 50rpx; border-radius: 25rpx; background: #eeece4; color: #333; white-space: nowrap;}.container-head-sc .item { padding: 0 20rpx; min-width: 90rpx; text-align: center; line-height: 50rpx; font-size: 26rpx; display: inline-block; height: 50rpx;}给每个tab设置vertical-align: top;防止高度塌陷.container-head-sc .item{ /* 防止高度塌陷 */ + vertical-align: top;}添加当前激活tab样式,定义当前选中项索引currentTab默认为0(即选中第一个),当currentTab==列表的某一项索引表示选中 <view class="item {{currentTab == index ?'active':''}}" data-current="{{index}}" catchtap="handleTabChange" wx:key="list" wx:for="{{list}}" wx:for-index="index">tab-{{index+1}} </view>.container-head-sc .active { color: #ffffff; font-weight: bold; background: orange; border-radius: 25rpx;}添加切换事件 handleTabChange(e) {let { current } = e.target.dataset;if (this.data.currentTab == current || current === undefined) return;this.setData({ currentTab: current,});},2.2 swiper+scroll-iew 实现内容列表

swiper: 滑块视图容器。默认高度为150px; current(number):当前所在滑块的 index,默认为0 autoplay(boolean):是否自动切换 bindchange(eventhandle):current 改变时会触发 change 事件,event.detail = {current, source}

swiper包裹内容列表,需要为swiper指定高度,这里我们设置为撑满一屏

/* swiper默认高度为150px */.container-swiper { height: calc(100% - 110rpx);}设置swiper的current为当前选中的tab标签索引,即currentTab<swiper current="{{currentTab}}" class="container-swiper"> <swiper-item class="flex-column j_c" wx:for="{{list}}" wx:key='index'> </swiper-item></swiper>swiper-item展示内容列表,用scroll-view包裹内容,设置竖向滚动,使用竖向滚动时,需要给scroll-view一个固定高度,这里将scroll-view高度设置为100%,与swiper同高,铺满一屏<swiper-item class="flex-column j_c" wx:for="{{list}}" wx:key='index'> <scroll-view scroll-y class="container-swiper-sc"> <view class="flex-wrap flex-row items"> ....//内容 </view> </scroll-view> </swiper-item>.container-swiper-sc { height: 100%;}swiper添加bindchange事件,当滑动时候,动态的设置currentTab,实现tab列表的同步更新 <swiper current="{{currentTab}}" bindchange="handleSwiperChange" class="container-swiper">....//内容</swiper> handleSwiperChange(e) { this.setData({ currentTab: e.detail.current, }); },可以发现,当swiper所在滑块的 index超出tab列表的可视范围,我们得手动滑动tab列表才能看见当前所选中的tab找到2.1节 scroll-left=“{{sleft}}”,scroll-left用来设置横向滚动条位置,也就是说,我们可以监听swiper的滚动,在滑块所在的index改变的时候,去动态的设置scroll-left的位置scroll-left的计算

wx.createSelectorQuery(): 返回一个 SelectorQuery 对象实例 SelectorQuery.selectAll(string selector): 在当前页面下选择匹配选择器 selector 的所有节点。

getScrollLeft() {const query = wx.createSelectorQuery();query.selectAll(".item").boundingClientRect();//这里将会返回页面中所有class为item的节点,个数为tab列表的长度query.exec((res) => { let num = 0; for (let i = 0; i < this.data.currentTab; i++) { num += res[0][i].width; } // 计算当前currentTab之前的宽度总和 this.setData({ sleft: Math.ceil(num), });});},修改swiper的bindchange事件,每次滑块的变化,都重新计算scroll-left的大小 handleSwiperChange(e) { + this.getScrollLeft(); },3.实现代码<view class="head flex-row"> <view class="head-title">scroll-left</view></view><scroll-view scroll-y class="container"> <view class="container-head flex-row"> <scroll-view scroll-x class="container-head-sc" scroll-left="{{sleft}}" scroll-with-animation="true"> <view class="item {{currentTab == index ?'active':''}}" data-current="{{index}}" catchtap="handleTabChange" wx:key="list" wx:for="{{list}}" wx:for-index="index">tab-{{index+1}} </view> </scroll-view> </view> <swiper current="{{currentTab}}" bindchange="handleSwiperChange" class="container-swiper"> <swiper-item class="flex-column j_c" wx:for="{{list}}" wx:key='index'> <scroll-view scroll-y class="container-swiper-sc"> <view class="flex-wrap flex-row items"> <block wx:for="{{item}}" wx:key="index"> <image src="https://www.yuucn.com/wp-content/uploads/2023/04/1682149599-47bec120528c89e.jpg" mode="aspectFill" class="item-img" /> </block> </view> </scroll-view> </swiper-item> </swiper></scroll-view>page { background-color: #ffa500; height: 100%;}.head { height: 90rpx; color: #333; font-size: 30rpx; padding-left: 30rpx; font-weight: bold; padding-bottom: 10rpx; box-sizing: border-box;}.head-title { position: relative; display: inline-block; height: 100%;}.head-title::after { content: ''; position: absolute; z-index: 99; width: 15px; height: 15px; margin-left: -15rpx; border-top: 3px solid #333; border-right: 3px solid #333; border-top-right-radius: 100%; transform: rotate(-225deg); left: 50%; bottom: 3px;}.container { width: 100%; height: calc(100% - 90rpx); background-color: #fff; overflow: hidden; border-radius: 30rpx 30rpx 0 0;}.container-head { width: 100%; height: 110rpx; box-sizing: border-box; padding: 10rpx 20rpx;}.container-head-sc { height: 50rpx; border-radius: 25rpx; background: #eeece4; color: #333; white-space: nowrap;}.container-head-sc .item { padding: 0 20rpx; min-width: 90rpx; text-align: center; line-height: 50rpx; font-size: 26rpx; display: inline-block; /* 引起高度塌陷 */ vertical-align: top; height: 50rpx;}.container-head-sc .active { color: #ffffff; font-weight: bold; background: orange; border-radius: 25rpx;}/* swiper默认高度为150px */.container-swiper { height: calc(100% - 110rpx);}.container-swiper-sc { height: 100%;}.container-swiper-sc .items { padding: 0 2%; width: 100%; box-sizing: border-box;}.container-swiper-sc .items .item-img { width: 30vw; height: 30vw; margin-right: 2.8%; margin-bottom: 10rpx; flex-shrink: 0;}.container-swiper-sc .items .item-img:nth-child(3n+3) { margin-right: 0;}/* 隐藏scroll-view的滚动条 */::-webkit-scrollbar { width: 0; height: 0; color: transparent;}Page({ data: { currentTab: 0, sleft: "", //横向滚动条位置 list: [1, 2, 3, 4, 5, 6, 7, 22, 32],//测试列表 }, handleTabChange(e) { let { current } = e.target.dataset; if (this.data.currentTab == current || current === undefined) return; this.setData({ currentTab: current, }); }, handleSwiperChange(e) { this.setData({ currentTab: e.detail.current, }); this.getScrollLeft(); }, getScrollLeft() { const query = wx.createSelectorQuery(); query.selectAll(".item").boundingClientRect(); query.exec((res) => { let num = 0; for (let i = 0; i < this.data.currentTab; i++) { num += res[0][i].width; } this.setData({ sleft: Math.ceil(num), }); }); },});4.写在最后🍒看完本文如果觉得有用,记得点赞+关注+收藏鸭 🍕更多小程序相关,关注🍥苏苏的bug,🍡苏苏的github,🍪苏苏的码云~
本文链接地址:https://www.jiuchutong.com/zhishi/298790.html 转载请保留说明!

上一篇:用chatgpt写insar地质灾害的论文,重复率只有1.8%,chatgpt4.0写论文不是梦

下一篇:BERT模型基本理念、工作原理、配置讲解(图文解释)(bert模型能做什么)

  • 国家企业信用信息公示系统公司个体户怎么注册?

    国家企业信用信息公示系统公司个体户怎么注册?

  • win10如何退出安全模式(win10如何退出安全模式下重启)

    win10如何退出安全模式(win10如何退出安全模式下重启)

  • 荣耀时间怎么显示24(荣耀时间怎么显示农历日期)

    荣耀时间怎么显示24(荣耀时间怎么显示农历日期)

  • 华为荣耀可以以旧换新吗(华为荣耀以前手机自带的健身励志视频)

    华为荣耀可以以旧换新吗(华为荣耀以前手机自带的健身励志视频)

  • 抖音隐藏无效视频怎么回事(抖音隐藏无效视频是自己设置的吗)

    抖音隐藏无效视频怎么回事(抖音隐藏无效视频是自己设置的吗)

  • webshell攻击是什么(web攻击原理)

    webshell攻击是什么(web攻击原理)

  • 朋友圈发图片怎么配音乐(朋友圈发图片怎么加音乐进去)

    朋友圈发图片怎么配音乐(朋友圈发图片怎么加音乐进去)

  • 天猫国际发错货怎么处理(天猫国际发错货收到更贵的商品)

    天猫国际发错货怎么处理(天猫国际发错货收到更贵的商品)

  • 淘宝物流红色感叹号(物流显示红色感叹号显示物流异常)

    淘宝物流红色感叹号(物流显示红色感叹号显示物流异常)

  • 华为p20pro是曲面屏吗(华为p20pro是曲屏的吗)

    华为p20pro是曲面屏吗(华为p20pro是曲屏的吗)

  • qq限制加好友处理多少天(QQ限制加好友处理多久才能恢复)

    qq限制加好友处理多少天(QQ限制加好友处理多久才能恢复)

  • 计算机中cpu是指什么(计算机术语中cpu是指)

    计算机中cpu是指什么(计算机术语中cpu是指)

  • ipv4的ip地址有多少字节(ipv4的ip地址是几位的)

    ipv4的ip地址有多少字节(ipv4的ip地址是几位的)

  • 微信免打扰语音聊天还有提醒吗(微信免打扰语音电话有提示吗)

    微信免打扰语音聊天还有提醒吗(微信免打扰语音电话有提示吗)

  • 手机出现e网怎么回事(手机出现e网怎么办)

    手机出现e网怎么回事(手机出现e网怎么办)

  • hddled是什么线(hdd led是指)

    hddled是什么线(hdd led是指)

  • 电子计算器on是什么键(在电子计算器上on键是什么off键是什么ce键是什么)

    电子计算器on是什么键(在电子计算器上on键是什么off键是什么ce键是什么)

  • 苹果7后盖是什么材质(苹果7后盖是什么材料)

    苹果7后盖是什么材质(苹果7后盖是什么材料)

  • 中国电信网管专家服务是基于什么技术(中国电信网管专家服务报告)

    中国电信网管专家服务是基于什么技术(中国电信网管专家服务报告)

  • iwatch可以连接安卓手机吗(iWatch可以连接安卓吗)

    iwatch可以连接安卓手机吗(iWatch可以连接安卓吗)

  • 小红书是腾讯旗下的吗(小红书是属于腾讯旗下的吗)

    小红书是腾讯旗下的吗(小红书是属于腾讯旗下的吗)

  • 手机识别码要不要允许(手机识别码是干嘛的)

    手机识别码要不要允许(手机识别码是干嘛的)

  • 骁龙835手机有哪些(骁龙835手机大全)

    骁龙835手机有哪些(骁龙835手机大全)

  • 方正uefi启动U盘安装win8系统教程(方正电脑u盘启动按什么键)

    方正uefi启动U盘安装win8系统教程(方正电脑u盘启动按什么键)

  • 增值税的附加税比例
  • 发票未到怎么暂估入账
  • 水利建设基金可以按次申报吗
  • 印花税核定征收管理办法
  • 异地项目预缴个人所得税
  • 成品油经销企业开具的成品油电子专用发票
  • 房产税房产原值包括地价吗
  • 置换回房产怎么过户
  • 银行询证函费用计入财务费用还是管理费用
  • 制造费用处理
  • 没有成本票如何做账
  • 为员工购置小车怎么做账
  • 预付工程款的会计科目
  • 我的初级备考日记--你都没坚持,还谈什么未来
  • 营改增的销售额规定
  • 餐饮服务行业会计分析
  • 产品研发费用属于固定成本吗
  • 个税上月没有申报当月可以补报么
  • 一般纳税人申报哪些税种
  • windows hello用不了怎么办
  • 酒水专用发票税率
  • RAVMOND.exe - RAVMOND是什么进程.有什么作用
  • 备份计算机需要多久
  • 资本溢价是
  • owmngr.exe - owmngr是什么进程 作用是什么
  • php gd库
  • 增值税多交可以退税吗
  • 应交税金及附加包括哪些
  • jupyter用法
  • 毫米波雷达的硬件构成
  • 前端es2020
  • 公司租用员工的车辆交什么税
  • python3中rindex用法
  • 企业员工年终奖仲裁
  • 运用java解决的实际问题
  • 进料加工出口退税核销最新流程
  • 财政部监制的收据没有税号可以入账吗
  • 出差自己开车去开会怎么报销交通费
  • SQL Server 2008 R2 为用户权限分配的操作步骤
  • PostgreSQL 创建表分区
  • 体检费用需要缴哪些费用
  • 企业非正常损失如何处理
  • 非正常损失的货物
  • 用友结算成本处理在哪里
  • 买车险要先付钱再上牌吗
  • 股东转公户的钱叫什么
  • 购买税盘全额抵扣会计分录
  • 期初建账怎么做
  • 会计忘记申报税款会有什么影响
  • 新成立的企业可以申请一般纳税人吗
  • 预提费用取消了怎么调整
  • windows vista电脑
  • openbabel安装
  • os x10.11el capitan beta6更新了什么?os x10.11el capitan beta6发布下载
  • linux分割分区
  • centos8拨号上网
  • 红石使用基础教学
  • Mac显示桌面快捷键
  • win10系统组策略怎么打开
  • win7系统弹出好多停止运行程序
  • liunx改时间命令
  • dos所有命令的命令格式
  • shell备份文件脚本
  • 原生js实现ajax步骤
  • css模糊滤镜
  • 微信小程序访问相册权限在哪里
  • nodejs基础
  • 用python抓取网页数据的代码
  • android数据存储实验报告
  • python 中的列表
  • 医保可以异地交嘛
  • 北京市国家税务局网站官网
  • 国家税务局申请电子发票怎么申请
  • 单位没有缴纳个人医保
  • 异地户口如何办理护照
  • 国税系统三方协议
  • 增值税专用发票和普通发票的区别
  • 车船税发票丢了怎么补办
  • 资源税计税价格包括从坑口
  • 个人所得税法全文完整版2023个人工薪规定
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设