热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

微信小程序-展开收缩列表

代码源自于:微信小程序示例官方index.wxml1<blockwx:for-items{{list}}wx:key{{item.

代码源自于:微信小程序示例官方

 

 

 

 

index.wxml

 1 <block wx:for-items="{{list}}" wx:key="{{item.id}}">
 2   <view class="kind-list-item">
 3     <view id="{{item.id}}" class="kind-list-item-hd {{item.open ? 'kind-list-item-hd-show' : ''}}" bindtap="kindToggle">
 4       <view class="kind-list-text">{{item.name}}view>
 5     view>
 6     <view class="kind-list-item-bd {{item.open ? 'kind-list-item-bd-show' : ''}}">
 7       <view class="navigator-box {{item.open ? 'navigator-box-show' : ''}}">
 8         <block wx:for-items="{{item.pages}}" wx:for-item="page" wx:key="*item">
 9           <navigator url="pages/{{page}}/{{page}}" class="navigator">
10             <view class="navigator-text">{{page}}view>
11             
12             <view class="navigator-arrow">view>
13           navigator>
14         block>
15       view>
16     view>
17   view>
18 block>

 

index.css

 1 .navigator-box {
 2  opacity: 0;
 3  position: relative;
 4  background-color: #fff;
 5  line-height: 1.41176471;
 6  font-size: 34rpx;
 7  transform: translateY(-50%);
 8  transition: 0.3s;
 9 }
 10 
 11 .navigator-box-show {
 12  opacity: 1;
 13  transform: translateY(0);
 14 }
 15 
 16 .navigator {
 17  padding: 20rpx 30rpx;
 18  position: relative;
 19  display: flex;
 20  align-items: center;
 21 }
 22 
 23 .navigator:before {
 24  content: " ";
 25  position: absolute;
 26  left: 30rpx;
 27  top: 0;
 28  right: 30rpx;
 29  height: 1px;
 30  border-top: 1rpx solid #d8d8d8;
 31  color: #d8d8d8;
 32 }
 33 
 34 .navigator:first-child:before {
 35  display: none;
 36 }
 37 
 38 .navigator-text {
 39  flex: 1;
 40 }
 41 
 42 .navigator-arrow {
 43  padding-right: 26rpx;
 44  position: relative;
 45 }
 46 
 47 .navigator-arrow:after {
 48  content: " ";
 49  display: inline-block;
 50  height: 18rpx;
 51  width: 18rpx;
 52  border-width: 2rpx 2rpx 0 0;
 53  border-color: #888;
 54  border-style: solid;
 55  transform: matrix(0.71, 0.71, -0.71, 0.71, 0, 0);
 56  position: absolute;
 57  top: 50%;
 58  margin-top: -8rpx;
 59  right: 28rpx;
 60 }
 61 
 62 .kind-list-item {
 63  margin: 20rpx 0;
 64  background-color: #fff;
 65  border-radius: 4rpx;
 66  overflow: hidden;
 67  border-bottom: 1px dashed #888;
 68 }
 69 
 70 .kind-list-item:first-child {
 71  margin-top: 0;
 72 }
 73 
 74 .kind-list-text {
 75  flex: 1;
 76 }
 77 
 78 .kind-list-img {
 79  width: 60rpx;
 80  height: 60rpx;
 81 }
 82 
 83 .kind-list-item-hd {
 84  padding: 30rpx;
 85  display: flex;
 86  align-items: center;
 87  transition: opacity 0.3s;
 88 }
 89 
 90 .kind-list-item-hd-show {
 91  opacity: 0.2;
 92 }
 93 
 94 .kind-list-item-bd {
 95  height: 0;
 96  overflow: hidden;
 97 }
 98 
 99 .kind-list-item-bd-show {
100  height: auto;
101 }

 

index.js

 1 Page({  2  data: {  3  list: [{  4       id: 'view',  5       name: '视图容器',  6       open: false,  7       pages: ['view', 'scroll-view', 'swiper', 'movable-view', 'cover-view']  8  }, {  9       id: 'content', 10       name: '基础内容', 11       open: false, 12       pages: ['text', 'icon', 'progress', 'rich-text'] 13  }, { 14       id: 'form', 15       name: '表单组件', 16       open: false, 17       pages: ['button', 'checkbox', 'form', 'input', 'label', 'picker', 'picker-view', 'radio', 'slider', 'switch', 'textarea'] 18  }, { 19       id: 'nav', 20       name: '导航', 21       open: false, 22       pages: ['navigator'] 23  }, { 24       id: 'media', 25       name: '媒体组件', 26       open: false, 27       pages: ['image', 'audio', 'video', 'camera'] 28  }, { 29       id: 'map', 30       name: '地图', 31       pages: ['map'] 32  }, { 33       id: 'canvas', 34       name: '画布', 35       pages: ['canvas'] 36  }, { 37       id: 'open', 38       name: '开放能力', 39       pages: ['ad', 'open-data', 'web-view'] 40  }] 41  }, 42 
43   /** 44  * 收缩核心代码 45    */
46  kindToggle(e) { 47     const id = e.currentTarget.id 48     const list = this.data.list 49     for (let i = 0, len = list.length; i i) { 50       if (list[i].id === id) { 51         list[i].open = !list[i].open 52       } else { 53         list[i].open = false
54  } 55  } 56 
57     /** 58  * key和value名称一样时,可以省略 59  * 60  * list:list=>list 61      */
62     this.setData({ 63  list 64  }) 65  } 66 })

 

点击下载源码:示例-小程序展开收缩列表


推荐阅读
  • 在PHP中如何正确调用JavaScript变量及定义PHP变量的方法详解 ... [详细]
  • 在 Vue 应用开发中,页面状态管理和跨页面数据传递是常见需求。本文将详细介绍 Vue Router 提供的两种有效方式,帮助开发者高效地实现页面间的数据交互与状态同步,同时分享一些最佳实践和注意事项。 ... [详细]
  • 深入解析 Android 中 EditText 的 getLayoutParams 方法及其代码应用实例 ... [详细]
  • 微信小程序实现类似微博的无限回复功能,内置云开发数据库支持
    本文详细介绍了如何利用微信小程序实现类似于微博的无限回复功能,并充分利用了微信云开发的数据库支持。文中不仅提供了关键代码片段,还包含了完整的页面代码,方便开发者按需使用。此外,HTML页面中包含了一些示例图片,开发者可以根据个人喜好进行替换。文章还将展示详细的数据库结构设计,帮助读者更好地理解和实现这一功能。 ... [详细]
  • 在处理大规模数据数组时,优化分页组件对于提高页面加载速度和用户体验至关重要。本文探讨了如何通过高效的分页策略,减少数据渲染的负担,提升应用性能。具体方法包括懒加载、虚拟滚动和数据预取等技术,这些技术能够显著降低内存占用和提升响应速度。通过实际案例分析,展示了这些优化措施的有效性和可行性。 ... [详细]
  • 【问题】在Android开发中,当为EditText添加TextWatcher并实现onTextChanged方法时,会遇到一个问题:即使只对EditText进行一次修改(例如使用删除键删除一个字符),该方法也会被频繁触发。这不仅影响性能,还可能导致逻辑错误。本文将探讨这一问题的原因,并提供有效的解决方案,包括使用Handler或计时器来限制方法的调用频率,以及通过自定义TextWatcher来优化事件处理,从而提高应用的稳定性和用户体验。 ... [详细]
  • 本文探讨了使用JavaScript在不同页面间传递参数的技术方法。具体而言,从a.html页面跳转至b.html时,如何携带参数并使b.html替代当前页面显示,而非新开窗口。文中详细介绍了实现这一功能的代码及注释,帮助开发者更好地理解和应用该技术。 ... [详细]
  • 本文详细探讨了使用纯JavaScript开发经典贪吃蛇游戏的技术细节和实现方法。通过具体的代码示例,深入解析了游戏逻辑、动画效果及用户交互的实现过程,为开发者提供了宝贵的参考和实践经验。 ... [详细]
  • 本文详细探讨了 jQuery 中 `ajaxSubmit` 方法的使用技巧及其应用场景。首先,介绍了如何正确引入必要的脚本文件,如 `jquery.form.js` 和 `jquery-1.8.0.min.js`。接着,通过具体示例展示了如何利用 `ajaxSubmit` 方法实现表单的异步提交,包括数据的发送、接收和处理。此外,还讨论了该方法在不同场景下的应用,如文件上传、表单验证和动态更新页面内容等,提供了丰富的代码示例和最佳实践建议。 ... [详细]
  • 本文全面解析了JavaScript中的DOM操作,并提供了详细的实践指南。DOM节点(Node)通常代表一个标签、文本或HTML属性,每个节点都具有一个nodeType属性,用于标识其类型。文章深入探讨了DOM节点的创建、查询、修改和删除等操作,结合实际案例,帮助读者更好地理解和掌握DOM编程技术。 ... [详细]
  • ButterKnife 是一款用于 Android 开发的注解库,主要用于简化视图和事件绑定。本文详细介绍了 ButterKnife 的基础用法,包括如何通过注解实现字段和方法的绑定,以及在实际项目中的应用示例。此外,文章还提到了截至 2016 年 4 月 29 日,ButterKnife 的最新版本为 8.0.1,为开发者提供了最新的功能和性能优化。 ... [详细]
  • 本地存储组件实现对IE低版本浏览器的兼容性支持 ... [详细]
  • 大类|电阻器_使用Requests、Etree、BeautifulSoup、Pandas和Path库进行数据抓取与处理 | 将指定区域内容保存为HTML和Excel格式
    大类|电阻器_使用Requests、Etree、BeautifulSoup、Pandas和Path库进行数据抓取与处理 | 将指定区域内容保存为HTML和Excel格式 ... [详细]
  • 属性类 `Properties` 是 `Hashtable` 类的子类,用于存储键值对形式的数据。该类在 Java 中广泛应用于配置文件的读取与写入,支持字符串类型的键和值。通过 `Properties` 类,开发者可以方便地进行配置信息的管理,确保应用程序的灵活性和可维护性。此外,`Properties` 类还提供了加载和保存属性文件的方法,使其在实际开发中具有较高的实用价值。 ... [详细]
  • Flowable 流程图路径与节点展示:已执行节点高亮红色标记,增强可视化效果
    在Flowable流程图中,通常仅显示当前节点,而路径则需自行获取。特别是在多次驳回的情况下,节点可能会出现混乱。本文重点探讨了如何准确地展示流程图效果,包括已结束的流程和正在执行的流程。具体实现方法包括生成带有高亮红色标记的图片,以增强可视化效果,确保用户能够清晰地了解每个节点的状态。 ... [详细]
author-avatar
难耐五更寒
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有