时间:2021-05-26
直接上代码:
html:
<div class="bodyFont clearfloat" id="bodyFont" ref="bodyFont" :class="{bodyHeight:contentStatus}"> <div v-html="content"></div></div><div class="contentToggle" v-if="contentStatus" @click="contentStatus=!contentStatus">阅读全文</div>css:
.bodyFont{ .font-dpr(16px); color: #333; text-align: left; line-height:58px; word-break:break-all; word-wrap:break-word; padding-bottom: 30px; height:auto; overflow: hidden; max-height: 100%; p{margin:16px 0 0 0;} } .bodyHeight{ height:5000px; } .contentToggle{ height:60px; line-height:60px; text-align: center; color:@red; border:1px solid @red; border-radius: 5px; .font-dpr(14px); margin-bottom:30px; }js:
data(){ return { contentStatus:false, curHeight:0, bodyHeight:5000 }},mounted(){ setTimeout(()=>{ this.contentToggle(); },500) },methods:{ contentToggle(){ this.curHeight=this.$refs.bodyFont.offsetHeight; if(this.curHeight>this.bodyHeight){ this.contentStatus=true; }else{ this.contentStatus=false; } },}效果如图:
实现思路与注意的点:
1、获取内容的高度要等到dom加载完成之后,在mounted里加一个setTimeout函数,保证能真正获取到
2、当内容的高度高于自己设定的要展示的高度的时候,则只限定在自己要展示的高度中,加一个class解决,注意要overflow:hidden;
以上这篇vue实现文章内容过长点击阅读全文功能的实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
对于一个内容页的文章来说,如果这个文章内容过长或是其中有分类(排行),那么进行分页阅读无疑是最好的选择。如果一个文章内容不涉及分类,比如小说类等,那么页码按正常
博客的文章列表默认都是带简单的摘要文字的,这是为了方便访客先了解文章内容概要,访客只有对感兴趣的文章才点击阅读全文,以节省时间。但有些情况并非一定要输出摘要文字
博客的文章列表默认都是带简单的摘要文字的,这是为了方便访客先了解文章内容概要,访客只有对感兴趣的文章才点击阅读全文,以节省时间。但有些情况并非一定要输出摘要文字
本文实例为大家分享了vue-cli点击实现全屏功能的具体代码,供大家参考,具体内容如下项目中有点击按钮实现全屏功能方式一:js实现全屏代码如下:全屏export
记要开发文章展示列表界面时,想通过展示部分文章头内容达到基本信息概览的需求即可,并展示【点击展开阅读全文】的按钮以获取详情内容。参考了文章caibaojian.