微信小程序点击item使之滚动到屏幕中间位置


Posted in Javascript onMarch 25, 2020

1.需求

微信小程序点击item使之滚动到屏幕中间位置

想做类似猫眼电影选场次会自动滚动到屏幕中间的效果

如图是最终效果 

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?'on':''}}" 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

总结

到此这篇关于微信小程序点击item使之滚动到屏幕中间的文章就介绍到这了,更多相关微信小程序item滚动到屏幕中间内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Javascript 相关文章推荐
js 目录列举函数
Nov 06 Javascript
一个cssQuery对象 javascript脚本实现代码
Jul 21 Javascript
js 实现 input type=&quot;file&quot; 文件上传示例代码
Aug 07 Javascript
jquery实现动态画圆
Dec 04 Javascript
Javascript中的几种URL编码方法比较
Jan 23 Javascript
JS实现简易图片轮播效果的方法
Mar 25 Javascript
在JavaScript中操作时间之getMonth()方法的使用
Jun 10 Javascript
js实现登录框鼠标拖拽效果
Mar 09 Javascript
详解处理bootstrap4不支持远程静态框问题
Jul 20 Javascript
koa2+vue实现登陆及登录状态判断
Aug 15 Javascript
Vue双向绑定实现原理与方法详解
May 07 Javascript
JavaScript 引用类型实例详解【数组、对象、严格模式等】
May 13 Javascript
微信小程序scroll-view点击项自动居中效果的实现
Mar 25 #Javascript
微信小程序 flexbox layout快速实现基本布局的解决方案
Mar 24 #Javascript
安装多版本Vue-CLI的实现方法
Mar 24 #Javascript
js实现页面图片消除效果
Mar 24 #Javascript
js实现消灭星星(web简易版)
Mar 24 #Javascript
JavaScript实现移动端带transition动画的轮播效果
Mar 24 #Javascript
javascript实现滚动条效果
Mar 24 #Javascript
You might like
编译问题
2006/10/09 PHP
PHP nl2br函数 将换行字符转成 &amp;lt;br&amp;gt;
2009/08/21 PHP
php 多关键字 高亮显示实现代码
2012/04/23 PHP
php对mongodb的扩展(初出茅庐)
2012/11/11 PHP
PHP删除HTMl标签的实现代码
2013/06/30 PHP
北京奥运官方网站幻灯切换效果flash版打包下载
2008/01/30 Javascript
js添加select下默认的option的value和text的方法
2014/10/19 Javascript
JS 日期与时间戮相互转化的简单实例
2016/06/22 Javascript
JS使用JSON作为参数实例分析
2016/06/23 Javascript
JQuery组件基于Bootstrap的DropDownList(完整版)
2016/07/05 Javascript
vue中的非父子间的通讯问题简单的实例代码
2017/07/19 Javascript
JavaScript实现简单图片轮播效果
2017/08/21 Javascript
React实践之Tree组件的使用方法
2017/09/30 Javascript
Javascript中Math.max和Math.max.apply的区别和用法详解
2020/08/24 Javascript
将Emacs打造成强大的Python代码编辑工具
2015/11/20 Python
如何安装2019Pycharm最新版本(详细教程)
2019/09/26 Python
使用 Python 在京东上抢口罩的思路详解
2020/02/27 Python
python实现手势识别的示例(入门)
2020/04/15 Python
简单了解python shutil模块原理及使用方法
2020/04/28 Python
Python容器类型公共方法总结
2020/08/19 Python
Python 利用flask搭建一个共享服务器的步骤
2020/12/05 Python
python中pickle模块浅析
2020/12/29 Python
简单介绍HTML5中的文件导入
2015/05/08 HTML / CSS
美国背景检查、公共记录和人物搜索网站:BeenVerified
2018/02/25 全球购物
美国排名第一的泳池用品直接来源:In The Swim
2019/09/23 全球购物
Smilodox官方运动服装店:从运动服到健身配件
2020/08/27 全球购物
人力资源经理的岗位职责
2014/03/02 职场文书
爱与责任演讲稿
2014/05/20 职场文书
体育口号大全
2014/06/18 职场文书
促销活动总结模板
2014/07/01 职场文书
党的群众路线教育实践活动总结大会主持词
2014/10/30 职场文书
求职简历自荐信怎么写
2015/03/26 职场文书
2015年煤矿工作总结
2015/04/28 职场文书
电工实训心得体会
2016/01/14 职场文书
解决Tkinter中button按钮未按却主动执行command函数的问题
2021/05/23 Python
zabbix自定义监控nginx状态实现过程
2021/11/01 Servers