1.需求
想做类似猫眼电影选场次会自动滚动到屏幕中间的效果
如图是最终效果
2.分析
实现这种效果的方法有三种:
1.直接使用原生CSS+js;
2.使用swiper,一屏显示多个item,点击item会自动滚动到中间
3.使用微信的scroll-view配合JS实现
权衡了一下最终选择了第三个方案,比较是微信自带的方法,使用起来会比较流畅,swiper的话会比较臃肿,原生的话就比较麻烦,需要考虑的兼容问题比较多。
3.代码
wxml
<view class="items-box"> <scroll-view class="scroll-view_H" scroll-x="true" style="width: 100%" bindscroll="scrollMove" scroll-left='{{scrollLeft}}' scroll-with-animation="true"> <view class="scroll-wrapper"> <view id="scroll-item-{{index}}" class="item-pic {{selectItemIndex==index" wx:for="{{ticketDetails}}" wx:key="index" bindtap="selectItem" data-index="{{index}}" data-name="{{item.TicketTitle}}" data-ticketid='{{item.TicketId}}'> <image src='{{imgUrl}}{{item.TicketPostImg}}'></image> </view> </view> </scroll-view> </view> <view class="item-name" hidden="{{!selectItemName}}">{{selectItemName}}</view>
wxss
.items-box .item-pic image { width: 90rpx; height: 120rpx; } .items-box .item-pic.on image { width: 110rpx; height: 148rpx; border: 4rpx solid #2bb7b3; box-sizing: border-box; } .items-box .item-pic { margin: 0 20rpx; } .items-box .item-pic:first-child{ padding-left: 300rpx } .items-box .item-pic:last-child{ padding-right: 300rpx } .item-name { padding: 18rpx 0; background-color: #fff; font-size: 24rpx; font-weight: 500; color: #232324; text-align: center; } .items-box .scroll-wrapper { align-items: flex-end; padding: 32rpx 0 0 0; } .items-box .scroll-view_H { border: none; background-color: #edeff1; }
js
data:{ moveParams: { scrollLeft: 0 } } getRect(ele) { //获取点击元素的信息,ele为传入的id var that = this; //节点查询 wx.createSelectorQuery().select(ele).boundingClientRect(function (rect) { console.log(rect) let moveParams = that.data.moveParams; moveParams.subLeft = rect.left; moveParams.subHalfWidth = rect.width / 2; that.moveTo(); }).exec() }, moveTo: function () { let subLeft = this.data.moveParams.subLeft; let screenHalfWidth = this.data.moveParams.screenHalfWidth; let subHalfWidth = this.data.moveParams.subHalfWidth; let scrollLeft = this.data.moveParams.scrollLeft; let distance = subLeft - screenHalfWidth + subHalfWidth; scrollLeft = scrollLeft + distance; this.setData({ scrollLeft: scrollLeft }) }, scrollMove(e) { let moveParams = this.data.moveParams; moveParams.scrollLeft = e.detail.scrollLeft; this.setData({ moveParams: moveParams }) }, //选择项目 selectItem: function (e) { let ele = 'scroll-item-' + e.currentTarget.dataset.index this.getRect('#' + ele); },
首先获取屏幕的宽度,再获取点击元素的宽度,计算一下就可以获得应该滚动的距离,再更改scroll-left='{{scrollLeft}}'即可
微信获取元素宽高的方法
wx.createSelectorQuery().select(ele).boundingClientRect(function (rect) { }).exec()
https://developers.weixin.qq.com/miniprogram/dev/api/wxml/wx.createSelectorQuery.html
总结
华山资源网 Design By www.eoogi.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
华山资源网 Design By www.eoogi.com
暂无评论...
RTX 5090要首发 性能要翻倍!三星展示GDDR7显存
三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。
首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。
据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。
更新日志
2024年09月21日
2024年09月21日
- [ABC]安娜-胆麦发烧女声[6N纯银镀膜][2016[低速原抓WAV+CUE]
- 任天堂今晚举行直面会!第三方及独立游戏展示
- 《哆啦A梦的铜锣烧店物语》发售!开罗公式+哆啦A梦
- 任天堂公布《塞尔达传说》系列时间线:野炊与王泪独立在外
- 五条人.2012-一些风景2CD【刀马旦】【WAV+CUE】
- 陈奕迅.2013-Easons.Life演唱会2CD(2024环球红馆40复刻系列)【环球】【WAV+CUE】
- 许美静.1995-遗憾(新马版)【上华】【WAV+CUE】
- 《叶倩文 歌声情缘》[WAV+CUE][410MB]
- 《张国荣 首首动听经典不容错过 追忆的风 2CD》[WAV+CUE][870MB]
- 《腾格尔 容中尔甲 亚东 高原三星 男人篇 3CD》[WAV/分轨][1GB]
- 命运圣契公测实测可用兑换码大全 命运圣契最新兑换码分享
- 黑神话悟空上品疾蝠精魄获取方法一览|上品疾蝠精魄收集攻略
- 《七龙珠电光炸裂!ZERO》GT角色预告片曝光,15位新角色登场
- [ABC]安娜-胆麦发烧女声[6N纯银镀膜][2016[低速原抓WAV+CUE]
- NewViennaOctetViennaWindSoloists-TheDeccaRecordings(2024)18CD[24-48][FLAC]-7