• 技术文章 >web前端 >js教程

    在vue中如何实现阅读全文

    亚连亚连2018-06-14 17:51:42原创1320
    下面我就为大家分享一篇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中文网其它相关文章!

    声明:本文原创发布php中文网,转载请注明出处,感谢您的尊重!如有疑问,请联系admin@php.cn处理
    专题推荐:vue 点击 阅读全文
    上一篇:在vue中如何获取dom元素 下一篇:在webpack上如何搭建vue项目
    大前端线上培训班

    相关文章推荐

    • javascript怎么设置p的值• javascript如何获取当前方法名• JavaScript如何获取HTML元素• javascript怎么检测变量是否存在• JavaScript中数组如何遍历

    全部评论我要评论

  • 取消发布评论发送
  • 1/1

    PHP中文网