首頁 >web前端 >js教程 >在vue中如何實現閱讀全文

在vue中如何實現閱讀全文

亚连
亚连原創
2018-06-14 17:51:422957瀏覽

下面我就為大家分享一篇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-cli中如何實作為單獨頁面設定背景色

在vue中實作刷新和tab切換

詳解解讀在vue專案中引入elementUI元件

以上是在vue中如何實現閱讀全文的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn