• vue实现文章内容过长点击阅读全文功能


    直接上代码:

    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;

  • 相关阅读:
    制作U盘启动安装CentOS Linux系统
    理解lua中 . : self
    LUA 运算笔记
    技能系统的数据结构
    关于数据结构(二)
    关于数据结构(一)
    WLW/OLW 最佳博客写作软件
    提升ReSharper和Visual Studio的性能
    ReSharper导致Visual Studio缓慢?
    ReSharper 全教程
  • 原文地址:https://www.cnblogs.com/beileixinqing/p/8126646.html
Copyright © 2020-2023  润新知