微信小程序实现折叠与展开文章功能


Posted in Javascript onJune 12, 2018

需求

页面折叠超出的的部分显示省略号,点击展开后显示全部内容

微信小程序实现折叠与展开文章功能

需要解决的问题

  • 箭头随展开折叠后箭头方向的变化
  • 当点击箭头文本显示内容的变化

如何解决?

  • 箭头方向的变化是一个点击事件bindtap,点击后更换小图标;
  • 文本变化是一个show或者hide的事情,折叠的时候有个多行文本溢出得问题五个属性(display: -webkit-box,-webkit-box-orient: vertical, -webkit-line-clamp,text-overflow,overflow)
  • 状态与数据绑定控制样式

具体实现

wxml

<view class="company-detail">
    <view class="company-detail-content">
      <view class="weui-loadmore weui-loadmore_line">
        <view class="weui-loadmore__tips weui-loadmore__tips_in-line">公司介绍</view>
      </view>
      <view class="long-dec {{isFold?'hide':'show'}}">
        <text class="first-dec">
          创业是个失败概率很大的事情,我们很高兴从2012底到现在还活着, 而且还活的很不错。 目前有赞旗下的产品有:有赞微商城、有赞收银、有赞零售、有赞美业、有赞批发、有赞买家版、有赞微小店.
        </text>
        <text class="second-dec">
          我们认为,相比较业务来说,团队才是公司的核心。有赞没有“员工”只有“小伙伴”,也没有人姓“公”名“司”,我们有一群聪明、有要性、又皮实的伙伴,这才是我们最大的资产。
        </text>
        <text class="last-dec">
          有赞的小伙伴目前已超过1000人,工程师比例占55%,我们有很浓的工程师氛围,每周都有很多的有意思的分享:有出国旅游的分享、有如何搭讪的分享、有如何装修房子的分享...技术分享更是数不胜数。 我们的工作不是很轻松,但我们的氛围很轻松,很open,公司里随处可见骑着独轮车来回跑的工程师、懒人沙发、午睡吊篮、复古电话亭等等,每个月都有节日、新人表演、拓展、派对等,对我们来说,天天都可以是节日。我们倡导简单直接的沟通方式,希望做一家通透的公司。这里并没有过多的等级划分,你可以随时提出自己的意见和任何人PK。福利方面我们全额缴纳五险一金,每月980元的有赞E卡鼓励大家一起吃喝玩乐。工程师标配MacBookPro、大屏显示器和机械键盘。办公室里常备零食、水果,休息区有电视、游戏机、桌球、乒乓球、四驱赛车、桌游随时供大家放松减压。每天晚下班的打车费报销,每年给你和你的家人提供旅游和体检等等。
        </text>
      </view>
      <image class="arrow" src=" {{isFold?'../../youzan-image/down.png':'../../youzan-image/up.png'}}" bindtap="showAll"></image>
    </view>
  </view>

wxss

.long-dec{
  padding-left: 20rpx;
  margin-top: -87rpx;
  display: -webkit-box;/*关键属性*/
  font-size:28rpx;
  color:#cfcfd0;
  line-height: 40rpx;
  word-break: break-all;
  -webkit-box-orient: vertical;/* 关键属性 */
  -webkit-line-clamp:6;/* 关键属性 */
  overflow: hidden;/* 关键属性 */
  text-overflow:ellipsis;/* 超出内容显示省略号*/
}
.hide{
 display: -webkit-box;
}
.show{
 display: block;
}
.arrow{
 position: absolute;
 width: 40rpx;
 height: 43rpx;
 left: 50%;
 transform: translate(-50%);
}

js

Page({
 data: {
  isFold: true,
 },
showAll: function (e) {
  this.setData({
   isFold: !this.data.isFold,
  })
 }

总结

以上所述是小编给大家介绍的微信小程序折叠与展开文章的实现代码,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
JQuery 前台切换网站的样式实现
Jun 22 Javascript
JS实现弹性漂浮效果的广告代码
Sep 02 Javascript
jquery点击缩略图切换视频播放特效代码分享
Sep 15 Javascript
JavaScript的new date等日期函数在safari中遇到的坑
Oct 24 Javascript
Vuex之理解Getters的用法实例
Apr 19 Javascript
微信小程序上滑加载下拉刷新(onscrollLower)分批加载数据(一)
May 11 Javascript
详解react-router如何实现按需加载
Jun 15 Javascript
JS按钮闪烁功能的实现代码
Jul 21 Javascript
vue实现分页栏效果
Jun 28 Javascript
JS中的算法与数据结构之常见排序(Sort)算法详解
Aug 16 Javascript
BootstrapValidator验证用户名已存在(ajax)
Nov 08 Javascript
微信小程序学习之自定义滚动弹窗
Dec 20 Javascript
微信小程序收藏功能的实现代码
Jun 12 #Javascript
记一次webpack3升级webpack4的踩坑经历
Jun 12 #Javascript
webpack4之SplitChunksPlugin使用指南
Jun 12 #Javascript
详解webpack4升级指南以及从webpack3.x迁移
Jun 12 #Javascript
webpack分离css单独打包的方法
Jun 12 #Javascript
详解extract-text-webpack-plugin 的使用及安装
Jun 12 #Javascript
webpack 样式加载的实现原理
Jun 12 #Javascript
You might like
php运行出现Call to undefined function curl_init()的解决方法
2010/11/02 PHP
php中实现记住密码自动登录的代码
2011/03/02 PHP
PHP setcookie设置Cookie用法(及设置无效的问题)
2011/07/13 PHP
php表单请求获得数据求和示例
2014/05/15 PHP
PHP获取服务器端信息的方法
2014/11/28 PHP
php 调用ffmpeg获取视频信息的简单实现
2017/04/03 PHP
php简单随机字符串生成方法示例
2017/04/19 PHP
使用composer安装使用thinkphp6.0框架问题【视频教程】
2019/10/01 PHP
Jquery弹出窗口插件 LeanModal的使用方法
2012/03/10 Javascript
js自定义方法通过隐藏iframe实现文件下载
2013/02/21 Javascript
js跑马灯代码(自写)
2013/04/17 Javascript
JS获取iframe中marginHeight和marginWidth属性的方法
2015/04/01 Javascript
JavaScript中join()方法的使用简介
2015/06/09 Javascript
详解Javascript事件驱动编程
2016/01/03 Javascript
jQuery1.9+中删除了live以后的替代方法
2016/06/17 Javascript
AngularJS实现动态添加Option的方法
2017/05/17 Javascript
layui选项卡效果实现代码
2017/05/19 Javascript
AngularJS实现进度条功能示例
2017/07/05 Javascript
微信小程序 配置顶部导航条标题颜色的实现方法
2017/09/20 Javascript
vue中利用simplemde实现markdown编辑器(增加图片上传功能)
2019/04/29 Javascript
微信小程序在ios下Echarts图表不能滑动的问题解决
2019/07/10 Javascript
layui 点击重置按钮, select 并没有被重置的解决方法
2019/09/03 Javascript
如何在wxml中直接写js代码(wxs)
2019/11/14 Javascript
vue $router和$route的区别详解
2020/12/02 Vue.js
Python计算一个文件里字数的方法
2015/06/15 Python
Python调用系统底层API播放wav文件的方法
2017/08/11 Python
Python使用pickle模块存储数据报错解决示例代码
2018/01/26 Python
Django rest framework基本介绍与代码示例
2018/01/26 Python
python集合是否可变总结
2019/06/20 Python
python tornado使用流生成图片的例子
2019/11/18 Python
python argparse模块通过后台传递参数实例
2020/04/20 Python
如何更换python默认编辑器的背景色
2020/08/10 Python
新西兰演唱会和体育门票网站:Ticketmaster新西兰
2017/10/07 全球购物
西安众合通用.net笔试题
2013/03/18 面试题
社区文明倡议书
2015/04/28 职场文书
解决 Redis 秒杀超卖场景的高并发
2022/04/12 Redis