• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号
您的位置:首页 > 程序设计 >微信小程序 > 两行代码实现微信小程序联系人sidebar

两行代码实现微信小程序联系人sidebar

作者:匿名 字体:[增加 减小] 来源:互联网 时间:2018-11-30

匿名通过本文主要向大家介绍了微信小程序等相关知识,希望对您有所帮助,也希望大家支持linkedu.com www.linkedu.com
一、数据:

city的json array,letter的array

(city的json array里的首字母是我手工放置进去的,你也可以通过for循环获得city_en的第一个字符来自动添加,但是为了赢得了性能我舍弃了灵活性)

两行代码实现微信小程序联系人sidebar

两行代码实现微信小程序联系人sidebar

二、布局:左边是scollview,右边是sidebar,这个布局要是布不好,可以先去了解下“flex布局”

两行代码实现微信小程序联系人sidebar

三、sidebar布局,让sidebar-item的id为当前字母

两行代码实现微信小程序联系人sidebar

四、设置sidebar距离顶部50px,设置sidebar的Item为固定20px,这个是必须的

.sideBar {
  width: 5%;
  margin-top: 50px;
}

.sideBar-item {
  height: 20px;
}

五、在sidebar上添加事件bindtouchmove,这个事件可以获取当前手指触摸的位置(主要是获得距离屏幕顶部的pageY),下面是思路

   var pageY = 在touchmove事件e中获得pageY 

   var letterIndex = (pageY - sidebar距离顶部的50px)/sidebar item的高度20px

   var letter = charArray[letterIndex];

实际代码:

   let letterIndex = (e.changedTouches["0"].pageY- 50) / 20;
   let letter = this.data.letterArray[letterIndex - 1];

  在此,已经获得了你手指触摸的letter了

六、通过scroll-view的一个属性来让字母置顶在scroll-view:


scroll-to-view,可以把他的值设置为一个id,

scrollview的ABCD等索引的ID实际上就是ABCD本身,那么,把第四段落获得的letter通过this.setData({toview:letter});

至此,触摸sidebar就可以看到列表通过触摸在变化。

七、后记过程:


最近微信小程序很火爆,我也尝试着做个天气软件试试手,在做到城市列表的sidebar时难倒我了

首先了解scrollview的scroll-to-view属性,把一个ID值赋给这个属性,那么对应ID值的组件就会置顶在scrollview的顶部,举例:

如果“赣州”这个item的id是ganzhou,那你把scroll-to-view的值设置成ganzhou,那scrollview一打开赣州就会出现在顶部。

接着,研究微信小程序的“事件”,微信小程序的事件有以下这些

两行代码实现微信小程序联系人sidebar

在一个个尝试后,发现touchmove是最适合自己的,我原本想的是,

既然touchmove事件会返回touch位置的组件信息,那么我就可以根据组件获得ID值,把ID的值再赋给scoll-to-view,

但是实际上不是我想的这样,他不断返回的都是我手指最开始触摸位置的组件。

最后,我就琢磨让sidebar和sidebar item的位置固定,通过计算获得letter的位置。

更多两行代码实现微信小程序联系人sidebar相关文章请关注微课江湖!

分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

相关文章

  • 2018-11-30详解微信小程序 页面跳转 传递参数
  • 2018-11-30微信小程序request网络请求操作实例详解
  • 2018-08-20微信小程序媒体组件 audio
  • 2018-11-30微信小程序开发animation心跳的动画效果代码实例详解
  • 2018-11-30小程序开发之实现点击控件后选中其它反选功能实例详解
  • 2018-11-30小程序实现自动加载的完整代码
  • 2017-06-20微信小程序Markdown渲染库
  • 2018-11-30 微信小程序实现【回到顶部】的按钮效果
  • 2018-11-30详解微信小程序搭建及解决登录失败问题解决方法
  • 2018-11-30小程序实现语音识别经验分享

文章分类

  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号

最近更新的内容

    • 微信小程序 开发工具快捷键整理
    • 微信小程序之MaterialDesign--input组件
    • 从Chrome App看微信小程序的发展前景
    • 微信小程序新增的拖动组件movable-view的使用介绍
    • 微信小程序-小商城前台
    • 微信小程序城市定位的实现
    • 分享一个清理内存卡和U盘里垃圾的小程序
    • 微信小程序云开发服务端API 初始化方法init
    • 微信小程序 引用其他js文件实现代码
    • 微信小程序高仿手机QQ应用程序

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有