下面我就為大家分享一篇vue實現文章內容過長點擊閱讀全文功能的實例,具有很好的參考價值,希望對大家有所幫助。
直接上程式碼:
html:
<p class="bodyFont clearfloat" id="bodyFont" ref="bodyFont" :class="{bodyHeight:contentStatus}"> <p v-html="content"></p> </p> <p class="contentToggle" v-if="contentStatus" @click="contentStatus=!contentStatus">阅读全文</p>
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中如何實現閱讀全文的詳細內容。更多資訊請關注PHP中文網其他相關文章!