最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

在vue中如何实现阅读全文

来源:懂视网 责编:小OO 时间:2020-11-27 19:36:56
文档

在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=css。
推荐度:
导读直接上代码。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=css。
下面我就为大家分享一篇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中如何实现阅读全文

直接上代码。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=css。
推荐度:
标签: VUE 实现 阅读全文
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top