热门标签 | 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 })

 

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


推荐阅读
  • ASP.NET2.0数据教程之十四:使用FormView的模板
    本文介绍了在ASP.NET 2.0中使用FormView控件来实现自定义的显示外观,与GridView和DetailsView不同,FormView使用模板来呈现,可以实现不规则的外观呈现。同时还介绍了TemplateField的用法和FormView与DetailsView的区别。 ... [详细]
  • 在Android开发中,使用Picasso库可以实现对网络图片的等比例缩放。本文介绍了使用Picasso库进行图片缩放的方法,并提供了具体的代码实现。通过获取图片的宽高,计算目标宽度和高度,并创建新图实现等比例缩放。 ... [详细]
  • PHP图片截取方法及应用实例
    本文介绍了使用PHP动态切割JPEG图片的方法,并提供了应用实例,包括截取视频图、提取文章内容中的图片地址、裁切图片等问题。详细介绍了相关的PHP函数和参数的使用,以及图片切割的具体步骤。同时,还提供了一些注意事项和优化建议。通过本文的学习,读者可以掌握PHP图片截取的技巧,实现自己的需求。 ... [详细]
  • 工作经验谈之-让百度地图API调用数据库内容 及详解
    这段时间,所在项目中要用到的一个模块,就是让数据库中的内容在百度地图上展现出来,如经纬度。主要实现以下几点功能:1.读取数据库中的经纬度值在百度上标注出来。2.点击标注弹出对应信息。3 ... [详细]
  • vue使用
    关键词: ... [详细]
  • 本文介绍了OC学习笔记中的@property和@synthesize,包括属性的定义和合成的使用方法。通过示例代码详细讲解了@property和@synthesize的作用和用法。 ... [详细]
  • eclipse学习(第三章:ssh中的Hibernate)——11.Hibernate的缓存(2级缓存,get和load)
    本文介绍了eclipse学习中的第三章内容,主要讲解了ssh中的Hibernate的缓存,包括2级缓存和get方法、load方法的区别。文章还涉及了项目实践和相关知识点的讲解。 ... [详细]
  • 本文讨论了一个关于cuowu类的问题,作者在使用cuowu类时遇到了错误提示和使用AdjustmentListener的问题。文章提供了16个解决方案,并给出了两个可能导致错误的原因。 ... [详细]
  • 1,关于死锁的理解死锁,我们可以简单的理解为是两个线程同时使用同一资源,两个线程又得不到相应的资源而造成永无相互等待的情况。 2,模拟死锁背景介绍:我们创建一个朋友 ... [详细]
  • 本文介绍了Web学习历程记录中关于Tomcat的基本概念和配置。首先解释了Web静态Web资源和动态Web资源的概念,以及C/S架构和B/S架构的区别。然后介绍了常见的Web服务器,包括Weblogic、WebSphere和Tomcat。接着详细讲解了Tomcat的虚拟主机、web应用和虚拟路径映射的概念和配置过程。最后简要介绍了http协议的作用。本文内容详实,适合初学者了解Tomcat的基础知识。 ... [详细]
  • 本文介绍了前端人员必须知道的三个问题,即前端都做哪些事、前端都需要哪些技术,以及前端的发展阶段。初级阶段包括HTML、CSS、JavaScript和jQuery的基础知识。进阶阶段涵盖了面向对象编程、响应式设计、Ajax、HTML5等新兴技术。高级阶段包括架构基础、模块化开发、预编译和前沿规范等内容。此外,还介绍了一些后端服务,如Node.js。 ... [详细]
  • OpenMap教程4 – 图层概述
    本文介绍了OpenMap教程4中关于地图图层的内容,包括将ShapeLayer添加到MapBean中的方法,OpenMap支持的图层类型以及使用BufferedLayer创建图像的MapBean。此外,还介绍了Layer背景标志的作用和OMGraphicHandlerLayer的基础层类。 ... [详细]
  • 校园表白墙微信小程序,校园小情书、告白墙、论坛,大学表白墙搭建教程
    小程序的名字必须和你微信注册的名称一模一样在后台注册好小程序。mp.wx-union.cn后台域名https。mp.wx-union.cn ... [详细]
  • UsingPMA-2.5.2-rc2onPHP-4.1.2andnothavingDROPTABLEprivilege,whenI-sel ... [详细]
  • 点击后defaultEducation的值明明改变了,但props传给子组件却watch不到 ... [详细]
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社区 版权所有