1.思路,半透明是2个div,第一个div半透明定位到第二个div上,
盘点是否有省略号
:class="[this.showEllipsis==-1?'news_content_bottom_ellipsis':'']"
<div class="goodContent">
<div class="newsBg"></div>
<div class="news_content_bottom" id="news_content_bottom" :style="{height: scrollerHeight}" :class="[this.showEllipsis==-1?'news_content_bottom_ellipsis':'']">
文章内容
</div>
<p class="buttonAll" @click.stop.prevent="onShow" >{{showText}}
<em class="downArrow" v-if="showText=='展开全文'"></em>
<em class="upArrow" v-else></em>
</p>
</div>
2.样式
//透明div
.newsBg{
background: linear-gradient(180deg, rgba(255, 255, 255, 0.6) 0%, #FFFFFF 100%);
height:36px;
width: 100%;
position: absolute;
z-index: 10;
top:19px;
}
//内容div
.news_content_bottom{
margin-top:12px;
font-size:14px;
color: #303133FF;
overflow: hidden; /* 隐藏溢出内容 */
height:42px;
line-height: 22px;
.buttonAll{
margin-top:12px;
font-size:14px;
color: #303133FF;
}
.el-button{
font-size: 16px;
color: #333;
}
p{
padding:5px 0;
}
}
//省略号的css
.news_content_bottom_ellipsis{
margin-top:12px;
font-size:14px;
color: #303133FF;
overflow: hidden; /* 隐藏溢出内容 */
text-overflow: clip; /* 修剪文本 */
display: -webkit-box; /* 弹性布局 */
-webkit-box-orient: vertical; /* 从上向下垂直排列子元素 */
-webkit-line-clamp: 2; /* 限制文本仅显示前三行 */
}
3.js 展开与折叠,折叠的时候加上透明度class,展开去掉透明度class,并且固定2行文章的高度为42px
data(){
return {
charityDetailData:{},
scrollerHeight:'',
isHide:false,
showText:'展开全文',
showEllipsis:-1,//判断是否有省略号
newsDetail: {
}
}
},
methods:{
//慈善捐赠展开,收起
onShow(){
this.isHide=!this.isHide;
let contentH=document.getElementById("news_content_bottom");
let newsBg=document.querySelector(".newsBg");
let scrollTop = document.getElementById("news_content_bottom").offsetHeight;
if(scrollTop<=42){
contentH.style.overflow = 'hidden';
this.scrollerHeight = 'auto';
newsBg.style.display='none';
this.showText='收起'
this.showEllipsis='';
}else {
contentH.style.overflow = 'auto';
this.scrollerHeight = '42px';
this.showText='展开全文';
newsBg.style.display='block';
this.showEllipsis=-1;
}
},
}
4.最终的效果
外加一个渐变
background: linear-gradient(90deg, #FFFFFF 0%, #FFEACB 100%);
效果