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


Posted in Javascript onDecember 28, 2017

直接上代码:

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;
 }
 },
}

效果如图:

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

实现思路与注意的点:

1、获取内容的高度要等到dom加载完成之后,在mounted里加一个setTimeout函数,保证能真正获取到

2、当内容的高度高于自己设定的要展示的高度的时候,则只限定在自己要展示的高度中,加一个class解决,注意要overflow:hidden;

以上这篇vue实现文章内容过长点击阅读全文功能的实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
JavaScript 应用技巧集合[推荐]
Aug 30 Javascript
动态获取复选框checkbox选中个数的jquery代码
Jun 25 Javascript
js实现一个链接打开两个链接地址的方法
May 12 Javascript
jQuery事件绑定用法详解(附bind和live的区别)
Jan 19 Javascript
jQuery根据表单name获取值的方法
May 24 Javascript
JavaScript中instanceof运算符的使用示例
Jun 08 Javascript
Javascript基础_标记文字的实现方法
Jun 14 Javascript
JavaScript设计模式之代理模式详解
Jun 09 Javascript
AngularJS 事件发布机制
Aug 28 Javascript
vue-router懒加载速度缓慢问题及解决方法
Nov 25 Javascript
JQuery实现ajax请求的示例和注意事项
Dec 10 jQuery
vue使用echarts图表自适应的几种解决方案
Dec 04 Vue.js
webpack搭建vue 项目的步骤
Dec 27 #Javascript
JS实现留言板功能[楼层效果展示]
Dec 27 #Javascript
js判断节假日实例代码
Dec 27 #Javascript
Vue的实例、生命周期与Vue脚手架(vue-cli)实例详解
Dec 27 #Javascript
Angular实现的简单查询天气预报功能示例
Dec 27 #Javascript
Angular实现点击按钮后在上方显示输入内容的方法
Dec 27 #Javascript
Angular实现的日程表功能【可添加及隐藏显示内容】
Dec 27 #Javascript
You might like
PHP持久连接mysql_pconnect()函数使用介绍
2012/02/05 PHP
php内核解析:PHP中的哈希表
2014/01/30 PHP
php隐藏实际地址的文件下载方法
2015/04/18 PHP
PHP基于单例模式实现的数据库操作基类
2016/01/15 PHP
ThinkPHP框架分布式数据库连接方法详解
2017/03/14 PHP
PhpStorm本地断点调试的方法步骤
2018/05/21 PHP
关于IFRAME 自适应高度的研究
2006/07/20 Javascript
从Ajax到JQuery Ajax学习
2007/02/14 Javascript
理解JAVASCRIPT中hasOwnProperty()的作用
2013/06/05 Javascript
jQuery的attr与prop使用介绍
2013/10/10 Javascript
选择复选框按钮置灰否则按钮可用
2014/05/22 Javascript
jquery实现像栅栏一样左右滑出式二级菜单效果代码
2015/08/24 Javascript
JavaScript基本语法学习教程
2016/01/14 Javascript
Bootstrap轮播插件简单使用方法介绍
2016/06/21 Javascript
javascript 四十条常用技巧大全
2016/09/09 Javascript
基于jQuery Easyui实现登陆框界面
2017/07/10 jQuery
浅谈vue.js中v-for循环渲染
2017/07/26 Javascript
基于jQuery的左滑出现删除按钮的示例
2017/08/29 jQuery
JS简单实现滑动加载数据的方法示例
2017/10/18 Javascript
vue.js element-ui validate中代码不执行问题解决方法
2017/12/18 Javascript
webpack引入eslint配置详解
2018/01/22 Javascript
vue封装一个简单的div框选时间的组件的方法
2019/01/06 Javascript
Vue的H5页面唤起支付宝支付功能
2019/04/18 Javascript
使用Promise封装小程序wx.request的实现方法
2019/11/13 Javascript
Vue 自适应高度表格的实现方法
2020/05/13 Javascript
Vue 防止短时间内连续点击后多次触发请求的操作
2020/11/11 Javascript
Python注释详解
2016/06/01 Python
python实现mysql的读写分离及负载均衡
2018/02/04 Python
Python 使用with上下文实现计时功能
2018/03/09 Python
django 将自带的数据库sqlite3改成mysql实例
2020/07/09 Python
python 利用matplotlib在3D空间绘制二次抛物面的案例
2021/02/06 Python
台湾母婴用品购物网站:Infant婴之房
2018/06/15 全球购物
小学红领巾中秋节广播稿
2014/01/13 职场文书
大课间活动实施方案
2014/03/06 职场文书
李开复演讲稿
2014/05/24 职场文书
MongoDB使用profile分析慢查询的步骤
2021/04/30 MongoDB