微信小程序scroll-view组件实现滚动动画


Posted in Javascript onJanuary 31, 2018

本文实例为大家分享了scroll-view组件实现索引列表滚动动画效果,供大家参考,具体内容如下

效果图

实现原理

利用scroll-view的scroll-into-view属性进行定位;
利用scroll-view的scroll-with-animation属性实现滚动动画过度。

WXML

<view class="right-nav">
  <view bindtap="getCurrentCode" class="{{chooseIndex == index ? '.city-list-active' : ''}}" wx:for="{{cityList}}" style="height:{{codeHeight}}px" data-code="{{item.code}}" data-index="{{index}}">
  {{item.code}}
  </view>
</view>

<view class="city-layer {{isShowLayer ? '' : 'layer-hide'}}">
 {{codeY}}
</view>

<view class="current-choose-city">当前选择机场:{{chooseCity}}</view>
<scroll-view class="city-scroll" scroll-y="true" scroll-into-view="{{codeY}}" scroll-with-animation="true" style="height:{{cityHeight}}px" bindscroll="scroll">
  <view class="city-box" wx:for="{{cityList}}" wx:key="{{item.code}}">
    <view class="city-code" id="{{item.code}}">{{item.code}}</view>
    <view class="city-list" wx:for="{{item.cityList}}" wx:for-item="city" bindtap="getChooseCity" data-city="{{city}}"> 
       {{city}} 
    </view> 
  </view>
</scroll-view>

WXSS

.current-choose-city{
 position: fixed;
 width: 100%;
 height: 50px;
 line-height: 50px;
 padding: 0 10px;
 top: 0;
 left: 0;
 background-color: #fff;
 z-index: 10;
}
.right-nav{
 width: 30px;
 color: #888;
 text-align: center;
 position: fixed;
 bottom: 0;
 right: 0;
 background-color: rgb(200, 200, 200);
 z-index: 9;
}
.city-scroll{padding-top: 50px;}
.city-code{
 background-color: #f7f7f7;
}
.city-list,.city-code{
 height: 39px;
 line-height: 40px;
 padding: 0 30px 0 10px;
 overflow: hidden;
 border-bottom: 1px solid #c8c7cc;
}
.city-list-active{color:#007aff;}

/*提示点击的字母 */
.city-layer{
 width: 70px;
 height: 70px;
 line-height: 70px;
 text-align: center;
 border-radius: 50%;
 color: #fff;
 background-color: rgba(0, 0, 0, .7);
 position: fixed;
 top: calc(50% - 35px);
 left:calc(50% - 35px);
 z-index: 11;
}
.layer-hide{display: none;}

JS

var city_list = require('./city.js');

Page({
 data: {
  cityList: city_list.city,
  chooseCity: '您还未选择机场!',
  isShowLayer: false,
  chooseIndex: 0,
  codeY: 'A',
  codeHeight: null,
  cityHeight:null
 },
 onLoad (options) {
  var windowHeight = wx.getSystemInfoSync().windowHeight;
  this.setData({ 
   codeHeight: (windowHeight - 50) / this.data.cityList.length,
   cityHeight: windowHeight - 50,
  });
 },
 getCurrentCode(e){
  var self = this;
  this.setData({ 
   codeY: e.target.dataset.code,
   chooseIndex: e.target.dataset.index,
   isShowLayer: true 
  })
  setTimeout(() => {
   self.setData({ isShowLayer: false })
  },500);
 },
 getChooseCity(e){
  this.setData({ chooseCity: e.target.dataset.city });
 }
})

对比

对比结果总结

  • 由于scroll-view的scroll-into-view属性是滚动到指定id位置,所以,在列表的字母行加上id属性;
  • 由于scroll-view的scroll-into-view属性实现了滚动到指定位置,所以减少了scrollTop的计算;
  • 由于scroll-view的scroll-with-animation属性,实现了滚动动画过度效果;
  • 减少了计算scrollTop的循环消耗;
  • js代码量减少,减少this.setData方法的变量设置。

DEMO下载

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
javascript奇异的arguments分析
Oct 20 Javascript
javascript面向对象快速入门实例
Jan 13 Javascript
深入分析下javascript中的[]()+!
Jul 07 Javascript
JavaScript Array对象详解
Mar 01 Javascript
AngularJs  Using $location详解及示例代码
Sep 02 Javascript
深入探究node之Transform
Jul 20 Javascript
Three.js加载外部模型的教程详解
Nov 10 Javascript
React Native使用fetch实现图片上传的示例代码
Mar 07 Javascript
详解使用vue-admin-template的优化历程
May 20 Javascript
jquery实现动态创建form并提交的方法示例
May 27 jQuery
详解elementui之el-image-viewer(图片查看器)
Aug 30 Javascript
vue.js+elementUI实现点击左右箭头切换头像功能(类似轮播图效果)
Sep 05 Javascript
微信小程序实现全国机场索引列表
Jan 31 #Javascript
微信小程序radio组件使用详解
Jan 31 #Javascript
微信小程序checkbox组件使用详解
Jan 31 #Javascript
原生JS实现多个小球碰撞反弹效果示例
Jan 31 #Javascript
浅析Angular19 自定义表单控件
Jan 31 #Javascript
JavaScript实现计算多边形质心的方法示例
Jan 31 #Javascript
微信小程序switch开关选择器使用详解
Jan 31 #Javascript
You might like
PHP实现无限极分类图文教程
2014/11/25 PHP
phpmyadmin下载、安装、配置教程
2017/05/16 PHP
php strftime函数获取日期时间(switch用法)
2018/05/16 PHP
向大师们学习Javascript(视频与PPT)
2009/12/27 Javascript
google 搜索框添加关键字实现代码
2010/04/24 Javascript
为jQuery.Treeview添加右键菜单的实现代码
2010/10/22 Javascript
单击浏览器右上角的X关闭窗口弹出提示的小例子
2013/06/12 Javascript
禁止IE用右键的JS代码
2013/12/30 Javascript
JS版的date函数(和PHP的date函数一样)
2014/05/12 Javascript
轮播的简单实现方法
2016/07/28 Javascript
js自调用匿名函数的三种写法(推荐)
2016/08/19 Javascript
Json对象和字符串互相转换json数据拼接和JSON使用方式详细介绍(小结)
2016/10/25 Javascript
AngularJS入门教程之多视图切换用法示例
2016/11/02 Javascript
Angularjs验证用户输入的字符串是否为日期时间
2017/06/01 Javascript
微信小程序 websocket 实现SpringMVC+Spring+Mybatis
2017/08/04 Javascript
BootStrap模态框和select2合用时input无法获取焦点的解决方法
2017/09/01 Javascript
基于vue.js的分页插件详解
2017/11/27 Javascript
python实现自动登录人人网并访问最近来访者实例
2014/09/26 Python
Python爬取读者并制作成PDF
2015/03/10 Python
python实现趣味图片字符化
2019/04/30 Python
Python语法分析之字符串格式化
2019/06/13 Python
python实现beta分布概率密度函数的方法
2019/07/08 Python
django实现web接口 python3模拟Post请求方式
2019/11/19 Python
Python+Selenium实现自动化的环境搭建的步骤(图文)
2020/09/01 Python
image-set实现Retina屏幕下图片显示详细介绍
2012/12/24 HTML / CSS
css3实现超炫风车特效
2014/11/12 HTML / CSS
基于第一个PhoneGap(cordova)的应用详解
2013/05/03 HTML / CSS
使用phonegap获取设备的一些信息方法
2017/03/31 HTML / CSS
购买限量版收藏品、珠宝和礼品:Bradford Exchange
2016/09/23 全球购物
千元咖啡店的创业计划书范文
2013/12/29 职场文书
班班通项目实施方案
2014/02/25 职场文书
学生会干部自我鉴定2014
2014/09/18 职场文书
党小组意见范文
2015/06/08 职场文书
7个你应该知道的JS原生错误类型
2021/04/29 Javascript
python中的装饰器该如何使用
2021/06/18 Python
win10输入法不见了只能打出字母怎么解决?
2022/08/05 数码科技