卡片布局以及鼠标悬浮展示全部

简介: 卡片布局以及鼠标悬浮展示全部

界面要求


  1. 不论视口大小每行显示6个元素,文字超出长显示省略号(暂定显示一行)


  1. 当鼠标悬浮的时候,展示所有文字,卡片向下延展直到能够完全显示文字


先看效果图


image.png


分析


  • 第一个要求我们可以用flex布局实现,css控制文字效果


  • 第二个,我们可以采用外层嵌套div的方式控制,当鼠标悬浮的时候展示内层div

看一下代码实现吧👇


代码展示


  1. html元素


<div class="card_view">
  <div class="card_view-item" v-for="(card, index) in listData" :key="index">
    <card :cardData="{name:card.name}"></card>
  </div>
</div>


  1. 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);
}


  1. card 组件


<template>
  <div class="textCard">
    <div class="ellipsis card-name">{{cardData.name}}</div>
  </div>
<template>
<script>
 export default {
   name:'TextCard',
   props:{
    cardData: {
      type: Object,
      require: true
    }
   },
   components: {},
   data () {
     return {}
   },
 }
</script>
<style lang='less' rel='stylesheet/less' scoped>
.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;
    }
  }
}
</style>


目录
相关文章
12 个非常适合做项目的开源后台管理系统
12 个非常适合做项目的开源后台管理系统
1813 0
|
C++
基于Qt的简易计算器设计与实现
基于Qt的简易计算器设计与实现
653 0
|
SQL JSON 数据可视化
新的一年,带给你全新的DataV
2023已经到来,我们正在迎来春暖花开的新时节。在这新年到来之际,我们给广大的DataV用户带来了一份新年礼物 - 全新的DataV 7.0版本,下面小编就带大家看一看新版本中有哪些激动人心的升级。
新的一年,带给你全新的DataV
|
JavaScript 前端开发
js 文字超出长度用省略号代替,鼠标悬停并以悬浮框显示
js 文字超出长度用省略号代替,鼠标悬停并以悬浮框显示
|
6月前
|
存储 Cloud Native 数据管理
《云原生数据仓库:原理与实践》,深入浅出助力企业数智化升级
开启AI背景下的数据管理新时代,探索云原生数据仓库的核心技术
|
搜索推荐 算法 JavaScript
探索冒泡排序:原理、实现与优化
探索冒泡排序:原理、实现与优化
|
安全 前端开发 JavaScript
什么是同源策略?
什么是同源策略?
445 1
|
监控 JavaScript 前端开发
vue切换页面白屏问题怎么解决
vue切换页面白屏问题怎么解决
448 0
|
存储 Linux 开发工具
Git简介与工作原理:了解Git的基本概念、版本控制系统和分布式版本控制的工作原理
Git简介与工作原理:了解Git的基本概念、版本控制系统和分布式版本控制的工作原理
716 0
|
存储 边缘计算 安全
云端一体
云端一体
332 0