应用办公生活信息教育商业
投稿投诉
商业财经
汽车智能
教育国际
房产环球
信息数码
热点科技
生活手机
晨报新闻
办公软件
科学动态
应用生物
体育时事

自定义一个各端通用的文本省略组件(ellipsis)

  组件效果图:
  现有方案壁垒:
  如果你做的是前端开发,你可能会经常遇到长度不够或高度不够时进行文本省略,这个也很简单,如下css代码就可以实现1行或n行的自动省略:一行多余省略:。ttextoneline{overflow:hidden;textoverflow:ellipsis;whitespace:nowrap;}n行多余省略:。ttextnline{display:webkitbox;wordbreak:breakall;textoverflow:ellipsis;overflow:hidden;webkitboxorient:vertical;webkitlineclamp:2;只需改变这里值为n即可}
  上面针对多余文字通过省略隐藏达到样式不变的效果,但是用户无法看到内容的全部文字,或者说需要一些处理才可以让用户看到,例如点击跳转详情页展示或者tip提示组件等,总之用起来缺乏美感。
  场景描述:
  文本要能全部展示,而且通过用户主动触发展示与不展示。因为用户一般只会对自己感兴趣的文章才会看全文,这样就需要一个既能满足上面简单需求,又能满足全文查看,且方便用户操作的体验友好的组件,这也是本组件编写的目的。
  兼容性:
  需要全端兼容所以使用uniapp框架,满足easycom组件规范,用户导入hbuilder后直接通过标签引用使用,非常方便。
  实现原理:
  根据原view设置的默认显示行数、文字大小等信息,虚拟一个相同的view容器,该view中把文字全部展示出来,通过以上信息计算出每行大概有多少个字符(汉字算两个,其他算1个),根据字符数对全文内容进行截取,再通过原view高度和虚拟view高度比较如果相等则停止计算,得到最终需要显示的字符串进行渲染。
  直接上正文,自定义组件全过程:
  1。hbuilder新建一个项目,选择默认第一个hellouniapp模板即可;
  2。项目根目录下新建components目录;
  3。在components目录下新建组件目录,例如这里命名为kevyellipsis的组件目录;
  4。在kevyellipsis目录下新建kevyellipsis。vue文件,其内容为组件代码
  kevyellipsis。vue代码如下:templateviewclasstwrap!虚拟view用于计算,计算完成则消失viewclassttxthide:idhidvif!isCompute:style〔computeStyle(0)〕{{testContent?testContent:content}}{{showSymbol?。。。:}}textvifexpandTextcollapseTextclasstbutton{{expandText}}textview!真实显示的内容viewclasstellipsis:idid:style〔!isCompute?computeStyle(1):computeStyle(2)〕clickcontentClick{{(!isComputeexpand)?content:(actualContent(showSymbol?。。。:))}}textvifexpandTextcollapseTextshowSymbolclasstbuttonclick。stopchangeCollapse:style{color:actionFontColor,float:right}{{!expand?expandText:collapseText}}textview!这里加入了自定义的动态骨架屏友好反馈viewvif!isComputerows0classtskeletonviewclassskeletonsvfor(item,index)inrowsviewclassemptyviewviewviewviewtemplatestylelangscssscoped。twrap{width:100;boxsizing:borderbox;position:relative;}。ttxthide{wordbreak:breakword;position:absolute;top:999999px;left:999999px;zindex:1000;top:0rpx;width:100;margin:0rpx;textalign:justify;}。tellipsis{textalign:justify;boxsizing:borderbox;width:100;wordbreak:breakword;position:relative;left:99999px;}。tskeleton{width:100;height:100;boxsizing:borderbox;position:absolute;top:0rpx;left:0rpx;}。skeletons:firstchild{margintop:0rpx!important;}。skeletons{position:relative;display:block;overflow:hidden;width:100;height:32rpx;margintop:12rpx;backgroundcolor:rgba(0,0,0,0。06);boxsizing:borderbox;}。skeletons。empty{display:block;position:absolute;width:100;height:100;webkittransform:translateX(100);transform:translateX(100);background:lineargradient(90deg,transparent,rgba(216,216,216,0。753),transparent);webkitanimation:loading。8sinfinite;animation:loading。8sinfinite;}keyframesloading{100{webkittransform:translateX(100);transform:translateX(100);}}style
  5。在kevyellipsis同目录下新建kevyellipsis。min。js,即上面代码中引入的工具类,为了防止他人冒用这里进行了代码混淆(如需该工具类源码关注并评论回复留下邮箱),代码如下:usestrict;functiontypeof(e){return(typeoffunctiontypeofSymbolsymboltypeofSymbol。iterator?function(e){returntypeofe}:function(e){returnefunctiontypeofSymbole。constructorSymbole!Symbol。prototype?symbol:typeofe})(e)}functionownKeys(t,e){varo,nObject。keys(t);returnObject。getOwnPropertySymbols(oObject。getOwnPropertySymbols(t),e(oo。filter(function(e){returnObject。getOwnPropertyDescriptor(t,e)。enumerable})),n。push。apply(n,o)),n}functionobjectSpread(t){for(vare1;eprepdatatrack34strong组件使用strongprecodetemplateviewclasscontent!这里模拟通过请求js动态赋值kevyellipsisvifcontentcontent。length0:contentcontentfontcolor666666:fontsize32:rows3contentClickmyclickcollapseText收起expandText展开actionFontColor007affkevyellipsisviewclassmgview!这里模拟直接复制给组件(例如循环)kevyellipsiscontent这是一个uniapp通用的超长文本处理组件,简单的设置达到自动适配超长文本溢出兼容效果。这是一个uniapp通用的超长文本处理组件,简单的设置达到自动适配超长文本溢出兼容效果。这是一个uniapp通用的超长文本处理组件,简单的设置达到自动适配超长文本溢出兼容效果。这是一个uniapp通用的超长文本处理组件,简单的设置达到自动适配超长文本溢出兼容效果。这是一个uniapp通用的超长文本处理组件,简单的设置达到自动适配超长文本溢出兼容效果。这是一个uniapp通用的超长文本处理组件,简单的设置达到自动适配超长文本溢出兼容效果。fontcolor666666:fontsize32:rows3contentClickmyclickcollapseText收起expandText展开actionFontColor007affkevyellipsisviewtemplatestylescoped。content{boxsizing:borderbox;width:100;padding:24rpx;}。mg{padding:50rpx;}style方法和属性名称
  类型
  描述
  content
  String
  文本内容,默认’’
  rows
  Number
  展示行数,默认1
  fontSize
  Number
  文本字体大小,单位rpx,默认28
  fontColor
  String
  文本字体颜色,默认666666
  collapseText
  String
  收起操作的文案,默认’’
  expandText
  String
  展开操作的文案,默认’’
  actionFontColor
  String
  收起、展开操作文字颜色,默认’007aff’
  contentClick
  Func
  文本点击事件函数
  如果想用现成的,在插件详情页通过hbuilder直接导入即可,插件市场插件详情页地址为:
  https:ext。dcloud。net。cnplugin?id11511
  如果本文对您有帮助,还请帮忙点个赞或留下宝贵意见哦,总之谢谢您啦。

哪些省份高度依赖房地产行业?FinGraph每日财经图集FinGraph是一份图形化的财经专栏,为专注于全球市场和经济形势的专业人士提供简短、准确、全面的每日概览。文章内容不构成投资建议。中国1。在中国努力促进经济从今年的放缓……5失误3犯规!正负值7全队垫底!勇士赶紧交易他吧北京时间11月23日,真的没救了啊太子爷!发展联盟圣克鲁兹勇士队120104战胜盐湖城星队,本场比赛被下放的怀斯曼出战24分钟,10投7中,三分1中1,罚球1中0,得到15分1……2022。11。25时间延迟是相对论引起的效果之一根据广义相对论,质量会造成时空弯曲地球上海拔低的地方比海拔高的地方时间流逝会变慢也就是说住在高层楼的人比1楼的人老得快这样……李秀芳心之感悟李秀芳,从事法律工作,鹤壁市作家协会会员,作品散见于媒体和报刊,诗歌多次入选中诗报精华版。心之感悟文李秀芳人生就是一场接一场的经历,经历也无所谓高尚低俗,遇见……NBA历史上也没球员能做到,WNBA飞人打出神级数据北京时间8月29日,WNBA半决赛开打。芝加哥天空对阵康涅狄格太阳,系列赛的第一场比赛。比赛过程很激烈,最终芝加哥天空以6368惜败于康涅狄格太阳。系列赛0比1遗憾落后,有着女……国乒四朵金花竞争白热化!陈梦步刘诗雯后尘,敬业精神该学习马龙陈梦会步刘诗雯后尘吗?近段时间以来,热度最高的莫过于成都世乒赛国乒的参赛阵容,由于国乒采取了不同的选拔方式,导致即便是世乒赛还有不到一个月的时间就将举办,但是国乒依然最后两个参……OceanBase社区版4。0让企业使用门槛再降,中国数据库数据库为企业带来了什么?降本增效是最直接的体现,如OceanBase助力云南红塔银行系统整体成本降低了90,处理能力也由原来每秒钟200TPS提升到每秒钟8000TPS;稳定支……海外日本将允许L4级自动驾驶车辆上路行驶,2023年4月实施文:懂车帝原创常思玥〔懂车帝原创行业〕日前,据日媒报道,日本《道路交通法》修正案预计将于2023年4月1日起实施,值得注意的是,此法案列入了在特定条件下实现完全自动化驾驶……又一中超球员曝丑闻!骗财骗色单次消费1万5,俱乐部发声回应近日,中超联赛继续进行比赛。目前大部分球队的比赛形式愈发明朗,武汉三镇、山东泰山和上海申花牢牢占据着联赛的三强,其余球队则是不断努力,想要赶上第一集团的积分。令很多球迷感到惊讶……被低估的新能源汽车,奇瑞大蚂蚁仅售18。38万元,值得入手吗现在的新能源汽车相当火爆,不过即使在如此火爆的行情下,也有一些卖不好的车型,比如我们今天要说的这款车型,这款新车就是奇瑞大蚂蚁。很明显,奇瑞大蚂蚁是一款被低估的新能源汽车。目前……量子纠缠改变人类的时空观未来可以改变历史北京时间10月4日,2022年诺贝尔物理学奖揭晓,AlainAspect、JohnF。Clauser和AntonZeilinger。获奖。以表彰他们在纠缠光子实验、验证违反贝尔……房地产从业者还有没有未来在经济发展困难重重的今天,各行各业都殊为不易。作为国民经济支柱产业之一的房地产,在生死存亡之际迎来的政府的一波刺激拉动政策。除了2022年国庆开始的降息、退税、公积金跨区域使用……
入秋后才发现不流行靴子了!满大街都在穿乐福鞋,洋气百搭夏秋过渡的时候,换衣的同时也要记得换鞋,一下子面对那么多不同风格的鞋子款式,大家早如何选择呢?早些年很流行的长靴、短靴,今年似乎过时了,大街上没几个人穿!初秋建议大家多穿……国内基因编辑赛道排行榜病毒载体公司一:前言基因编辑(geneediting),又称基因组编辑(genomeediting)或基因组工程(genomeengineering),是一种新兴的比较精确的能对生物……MR。UNO社杂男孩王星越的AB面王星越发了一条失踪人口回归的微博。在休息的这段时间,他健身、旅游,还和朋友来了一次庐山的途自驾游。作为司机王师傅,王星越在自驾游中任劳任怨,全程开车。坐在驾驶位就是我的乐趣。累……硬核闯关脑洞破圈!建造游戏沉浮特邀测试落幕脑洞闯关欢乐多!国产海洋沙盒建造游戏《沉浮》已于年前顺利结束Steam冬季特邀测试。全新的物理搭建、单人闯关、多人海战等独特玩法带来了不同以往的奇妙体验。特邀测试提供了单……保险产品四季度新策略财富管理成新单增长动能增值服务仍是布局重南方财经全媒体记者孙诗卉实习生徐若萱上海报道近年来,随着我国人均可支配收入增加、人口老龄化及慢性病患病率上升,居民对健康保障需求越来越高。但随之而来的是保险市场竞争激烈,……用枸杞泡酒,能生精壮阳?为何酒后有些人会直接昏睡?重视养生的人会通过良好习惯养成来促进健康,尽可能提高抵抗力,保护重要器官,没有疾病影响,生活质量提高外延年益寿。但养生途径是否恰当要去了解,有的中老年人经常饮用药酒,利用各种中……嘉定农田发现狗獾!已送动物园疗伤为上海本土现存最大兽类东方网记者柏可林9月21日报道:据上海市林业总站消息,9月19日,嘉定区华亭镇双塘村村民陆先生在水稻田干农活时,发现一只头部具有黑白条纹的动物,随即与嘉定区林业站取得联系,并将……巅峰詹姆斯和巅峰字母哥,到底谁强谁弱?库里给出了答案谁是联盟最好的球员,对于这个话题的讨论从未间断过,去年字母哥率队获得总冠军后,库里当着记者的面表示,字母哥是最好的球员,今年库里率队获得总冠军以后,字母哥表示库里是最好的球员。……战地20422。1更新已上线地图重做推出新载具DICE宣布《战地2042》2。1更新已上线,推出重做后的地图涅槃(Renewal),以及新载具PolarisRZR等。据了解,PolarisRZR是一种更加轻便快速的双……日照游记,日照,这6条海岸线美哭了日照作为海滨小城,来到这里,怎么能不去看海呢绝美海岸线,一起去看看吧。周边出行公交:沿海地区都被开发成了景点,很多公交都有站牌,还有旅游1路,2路专门去海边打……群雄逐鹿TWS耳机市场,华为FreeBudsPro2和Air经过多年发展,TWS耳机市场越发成熟。数据机构Canalys预测,未来五年TWS耳机市场将保持高速增长,2024年市场总出货量预计将达到10。5亿副,年复合增长率为15。04。……浮生茶语余生,遇到一个懂你的人,足矣张爱玲在《爱》一文中写道,于千万人之中遇见你所要遇见的人,于千万年之中,时间的无涯的荒野里,没有早一步,也没有晚一步,刚巧赶上了,那也没有别的话可说,唯有轻轻地问一声:噢,你也……
友情链接:易事利快生活快传网聚热点七猫云快好知快百科中准网快好找文好找中准网快软网