小程序实现展开/收起的效果示例

前言:本章说下文字内容的展开与收起的实现,要实现这么一个效果:当收起的时候隐藏并显示省略号,当展开的时候显示全部文字

GitHub:https://github.com/Ewall1106/miniProgramDemo

先看下效果图:

小程序 — 展开/收起

1、结构样式

(1)首先我们定义一下html结构:

rush:xml;"> 标题标题

内容摘抄至马良《告坦白书》中我一段喜欢的文字

(2)less样式:

标题 title 就是一个简单的flex布局; 内容 content 中的文字我们认收起状态且只展示两行

rush:css;"> .container { .title { display: flex; flex-direction: row; justify-content: space-between; align-items: center; padding: 25rpx; .title_txt { font-size: 34rpx; color: #2b2b2b; } .title_icon { display: block; width: 21rpx; height: 11rpx; } } .content { height: 80rpx; overflow: hidden; text-overflow: ellipsis; text-overflow: -o-ellipsis-lastline; display: -webkit-Box; -webkit-line-clamp: 2; -webkit-Box-orient: vertical; padding: 0 25rpx; font-size: 30rpx; color: #888888; } }

(3)这样我们就实现了一个认布局样式

2、添加点击事件

(1)首先我们应该在 data 中定义一个变量 isShow 用来控制样式的切换,认为收起状态(即不展示)。

rush:js;"> data = { isShow: false };

(2)在箭头icon上添加一个点击事件,当点击的时候对 isShow 做取反操作;

rush:js;"> toggle() { this.isShow = !this.isShow; this.$apply(); }

3、样式动态切换

(1)首先是image箭头图片的切换(注意是如何动态的切换本地图片的)

rush:xhtml;">

(2)然后我们定义一个展开的样式,根据isShow的状态值动态的切换样式

rush:xhtml;">

.content.on {
display: block;
text-overflow: clip;
overflow: visible;
}

4、小结

这样我们就实现了文本框的展开/收起效果,当收起的时候显示省略号并隐藏,当展开的时候展示全部文字

当然,不仅仅是文字的收起与展开,里面放其它的内容也是可以的,根据需求来应对了;还有就是可以加个动画之类的完善一下交互效果,感兴趣的朋友可以自己鼓捣。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程之家。

相关文章

开发微信小程序的用户授权登录功能
小程序开发页面如何实现跳转?
浅谈小程序开发中蓝牙连接错误分析及解决方法
什么是小程序?它有哪些功能?
如何配置小程序开发项目结构?(教程)
怎么把自己的店加入小程序