界面要求
- 不论视口大小每行显示6个元素,文字超出长显示省略号(暂定显示一行)
- 当鼠标悬浮的时候,展示所有文字,卡片向下延展直到能够完全显示文字
文章图片
分析
- 第一个要求我们可以用
flex
布局实现,css控制文字效果 - 第二个,我们可以采用外层嵌套
div
的方式控制,当鼠标悬浮的时候展示内层div
代码展示
- html元素
- less控制每行布局
flex: 0 1 auto; (默认值为0 1 auto, 后两个属性可选)
三个参数分别是:
- flex-grow(放大比例),
- flex-shrink(缩小比例)
- flex-basis(占据主轴的空间)
.card_view {
display: flex;
justify-content: flex-start;
flex-flow: row wrap;
align-items: flex-start;
&-card {
border-radius: 8px;
cursor: pointer;
height: 36px;
position: relative;
margin-left: 16px;
margin-top: 16px;
}
&-item {
flex: 0 0 16.66%;
}
}
全局样式:
//文本溢出省略号
.ellipsis {
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis;
}
.clamp_fun(@line: 1) {
overflow: hidden;
text-overflow: ellipsis;
-webkit-box-orient: vertical;
display: -webkit-box;
-webkit-line-clamp: @line;
}
.clamp_1 {
.clamp_fun(1);
}
.clamp_2 {
.clamp_fun(2);
}
.clamp_3 {
.clamp_fun(3);
}
- card 组件
{{cardData.name}}.textCard {
border-radius: 8px;
cursor: pointer;
background-color: aqua;
height: 36px;
position: relative;
margin-right: 16px;
margin-top: 16px;
color: #333;
.card-name {
position: absolute;
top: 0;
left: 0;
display: inline-block;
width: 100%;
padding: 8px 14px;
border-radius: 8px;
line-height: 20px;
box-sizing: border-box;
}
&:hover {
.card-name {
color: #fff;
white-space: normal !important;
overflow: unset !important;
background-color: aqua;
box-shadow: 0 6px 200px rgba(71, 96, 240, 0.2);
z-index: 9;
}
}
}
持续更文,关注我,你会发现一个踏实努力的宝藏前端,让我们一起学习,共同成长吧。
喜欢的小伙伴记得点赞关注收藏哟,回看不迷路
【卡片布局以及鼠标悬浮展示全部】 欢迎大家评论交流, 蟹蟹
推荐阅读
- 阿里前端智能化技术探索和未来思考
- 经验分享|电商项目——优惠券测试点有哪些()
- vue|vue: 解决错误 RunScriptError: post install error, please remove node_modules before retry!
- 2. 冒泡和快排
- 得物黑科技|AR测量脚型,解决尺码烦恼
- react.js|React Router V6实现嵌套路由重定向
- React|react-router之路由重定向
- 工作-React|2022-06-29 工作记录--React-函数式组件 useState的使用 + useEffect的使用 + 监听事件的使用
- 学习|React组件基础