Loading [MathJax]/jax/output/CommonHTML/config.js
前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >布局之悬浮显示更多文本并增加箭头指示效果

布局之悬浮显示更多文本并增加箭头指示效果

作者头像
甜点cc
发布于 2022-09-23 07:55:56
发布于 2022-09-23 07:55:56
79200
代码可运行
举报
运行总次数:0
代码可运行

记录一个界面交互的小功能

UI效果图

需求描述

  1. 文本只显示一行,超出显示省略号
  2. 文本超出显示省略号的同时,在右侧显示箭头指示,否则,不显示箭头
  3. 鼠标悬浮展示全部文本,箭头转向

思路分析

  1. 先不考虑右侧"箭头",单纯的鼠标悬浮展示全部不难实现(前面【卡片布局...】一文中已经实现过,本文代码是在上篇之上修改)
  2. 控制箭头交互的时候,把文本元素和箭头元素分别设置宽度
  3. 通过过渡(transtion)控制鼠标悬浮箭头转向
  4. 通过自定义指令控制“箭头”显示隐藏

代码展示

  1. card 组件
  2. html
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<template>
  <div class="textCard">
    <div class="ellipsis card-name">{{cardData.name}}</div>
    <!-- 箭头通过自定义指令控制 -->
    <i v-moreIcon class="el-icon-arrow-down icon_down"></i>
  </div>
</template>
  • less
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
.textCard {
  border-radius: 8px;
  cursor: pointer;
  background-color: chartreuse;
  height: 36px;
  position: relative;
  margin-right: 16px;
  margin-top: 16px;
  color: #333;
  .card-name {
    position: absolute;
    top: 0;
    left: 0;
    display: inline-block;
    max-width: calc(100% - 20px);
    // width: 100%;
    padding: 8px 0 8px 14px;
    border-radius: 8px;
    line-height: 20px;
    box-sizing: border-box;
  }
  &:hover {
    .card-name {
      white-space: normal !important;
      overflow: unset !important;
      background-color: chartreuse;
      box-shadow: 0 6px 20px rgba(72, 88, 183, 0.2);
      z-index: 9;
      width: 100%;
      max-width: unset !important;
      padding-right: 14px;
    }
    .icon_down {
      z-index: 10;
      transform: translateY(-50%) rotate(180deg);
      transition: transform 0.1s;
    }
  }
  .icon_down {
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%) rotate(0deg);
    transform-origin: center;
    width: 20px;
    font-size: 12px;
    text-align: center;
  }
}
  1. 自定义指令控制箭头
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
// 注册全局自定义指令 `v-moreIcon`
import Vue from "vue";

Vue.directive("moreIcon", {
  // 被绑定
  bind: function () {},
  // 绑定元素插入到DOM节点
  inserted: function (el) {
    // 绑定元素的父元素
    const p_w = el.parentNode.offsetWidth;
    // 绑定元素的上一个兄弟元素
    const s_w = el.previousElementSibling.offsetWidth;

    // 20: icon 的宽度; 文本的最大宽度 calc(100% - 20px)
    if (p_w - s_w <= 20) {
      // 一行文本已满格,显示icon
    } else {
      // 文本没有满一行,隐藏icon
      el.style.display = 'none'
    }
  },
  // 组件更新调用
  update: function () {},
  // 组件更新完成
  componentUpdated: function () {},
  // 解绑
  unbind: function () {},
});

实现效果

在已有功能上实现的类似UI图的效果


🎈🎈🎈

🌹 持续更文,关注我,你会发现一个踏实努力的宝藏前端😊,让我们一起学习,共同成长吧。

🎉 喜欢的小伙伴记得点赞关注收藏哟,回看不迷路 😉

🎁 欢迎大家评论交流, 蟹蟹😊

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022-08-23,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
卡片布局以及鼠标悬浮展示全部
界面要求 不论视口大小每行显示6个元素,文字超出长显示省略号(暂定显示一行) 当鼠标悬浮的时候,展示所有文字,卡片向下延展直到能够完全显示文字 先看效果图 分析 第一个要求我们可以用flex布局实现,css控制文字效果 第二个,我们可以采用外层嵌套div的方式控制,当鼠标悬浮的时候展示内层div 看一下代码实现吧👇 代码展示 html元素 <div class="card_view"> <div class="card_view-item" v-for="(card, in
甜点cc
2022/09/26
7610
卡片布局以及鼠标悬浮展示全部
魔改笔记六:twikoo及导航栏美化
顶栏动效曾令我费尽心思,眼见鱼鱼和洪哥的导航栏动画如此流畅,随着页面的上下切换标题和菜单,我感到无比畅快。然而,我发现的教程中都未能实现如此平滑的过渡。因此,我使用所学知识,在他人基础上进行改进,最终达成了我心目中的效果。至于 Twikoo 的美化,一开始我觉得原版实在不够美观,于是决定自行修改。在修改过程中,我也参考了一些小伙伴的内容,你可以在下方的引用链接中查看。
柳神
2024/05/30
2800
魔改笔记六:twikoo及导航栏美化
视差特效的原理和实现方法
本文的 『推荐』 部分也别错过喔~ 因为日常开发很少使用原生的方式去做视差效果。
德育处主任
2022/04/17
2.1K0
视差特效的原理和实现方法
使用CSS3 transform:matrix3d实现的搜索框变形动画
JQ的实现主要是操作DOM,$选择器,判断一个元素里面有没有class类,可以用hasClass方法
itclanCoder
2023/09/14
3990
使用CSS3 transform:matrix3d实现的搜索框变形动画
CSS3知识点整理&&一些demo
1.圆角效果 border-radius:border-radius: 5px 4px 3px 2px; /* 四个半径值分别是左上角、右上角、右下角和左下角,顺时针 */ border-radius: 100%;就是一个圆了。
牧云云
2022/03/10
6720
CSS3知识点整理&&一些demo
CSS3卡片光照效果
要实现卡片光照的效果,我们需要添加子元素,此时使用伪元素::after是最好的选择。我们需要给::after添加一个斜着的渐变来模拟光照效果,这里我们使用从左到右的渐变,然后再给一个倾斜的形变就可以模拟了。最好再给一个简单的悬浮动画就完事了。下面直接给出CSS的其他代码:
kai666666
2020/10/19
2K0
CSS3卡片光照效果
42个来自《 CSS世界》中的实用技巧
但是要注意,当p的内容为英文单词组成的时候,如果单词过长,而不是“ pppppppppppppppppppppppppppppp”这样的一次,会被视为一个单位而造成超过div的尺寸。
winty
2021/01/05
1.1K0
给 el-card 添加折叠功能
虽然 Element 也有 el-collapse 组件,但是当我只想写一个折叠面板时,它的写法就略显繁琐了,el-card 组件的样式也更符合我的需求,所以我就想着给 el-card 添加折叠功能。
Cell
2024/01/11
1.2K0
个人小站折腾后记
🧑个人简介:大家好,我是 shark-Gao,一个想要与大家共同进步的男人😉😉
程序员Leo
2023/08/08
1.2K0
个人小站折腾后记
55 个提高你 CSS 开发效率的必备片段
这篇文章会记录我们平时常用到的 CSS 片段,使用这些 CSS 可以帮助我们解决许多实际项目问题中遇到的,墙裂建议点赞收藏再看,方便日后查找? 清除浮动 浮动给我们的代码带来的麻烦,想必不需要多说,我
wscats
2020/06/06
1.4K0
光标有反转效果的侧边导航(附源代码)
这是一个侧边导航效果,这个展开的效果给人一种很柔和的感觉,展开后菜单内容依次显示,最后是增加了一个聚焦的圆跟随光标移动,当遇到菜单内容时会放大圆形并反转显示菜单文字,加深了对导航的交互,这里的反转色基于 mix-blend-mode: difference 实现。这个效果还有两个主题色切换,有兴趣的可以在线看效果。
半夜喝可乐
2024/10/10
1470
光标有反转效果的侧边导航(附源代码)
实现网站中增加春节灯笼动态效果
这篇文章最后修改于 2022-06-23 日,距今已有 153 天,请注意甄别内容是否已经过时!
羽翼博客
2022/11/28
5000
实现网站中增加春节灯笼动态效果
vuejs小例子之记事本
<html> <head> <script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script> <style> #app { margin: 0px auto; width: 500px; border: 1px solid blue; height: 500px; } .title { line-height: 50px; tex
西西嘛呦
2020/08/26
7820
纯css实现117个Loading效果(上)
这是我这几十年间从世界各地寻觅到的 Loading特效,合计117个(本文贴出第1-39个),而且是 纯CSS 制作的。
德育处主任
2022/04/15
2.8K0
纯css实现117个Loading效果(上)
原生HTML+CSS+JS制作自己的导航主页(前端大作业,源码+步骤详解)
咕咕了好久啦,今天使用原生HTML+CSS+JS做一个很简单的个人定制的导航主页吧!
全栈程序员站长
2022/09/15
7K2
原生HTML+CSS+JS制作自己的导航主页(前端大作业,源码+步骤详解)
如何给帖子添加板块角标,Ta来了!
因为我首页是没有板块的,这样的话帖子是什么板块的不点进帖子内就不好分辨。我是站在实用的角度出发,顺便做的好看一些,不是为了花里胡哨所谓的美化。所以不要问我这个怎么美化那个怎么美化,我不会因为我不美化。
用户1287596
2024/10/10
1300
SAO-UI-PLAN--Card-Player
这是SAO UI PLAN 的第五弹了,效果没有我想的那么理想。在面积有限的作者卡片上做文章实在是有些捉襟见肘,除了可以在配色上动动脑筋以外,没啥可以放内容的地方。
Akilar
2021/08/03
8700
CSS 3.0实现创意产品卡片
给大家分享一个用CSS 3.0实现的创意产品卡片,效果如下: 以下是代码实现,欢迎大家复制粘贴和收藏。 <!DOCTYPE html> <html lang="en"> <head> <me
越陌度阡
2020/11/26
4960
CSS 3.0实现创意产品卡片
衔接-玩转AI新声态 | 玩转TTS/ASR/YuanQI 打造自己的AI助手
衔接上一篇 玩转AI新声态 | 玩转TTS/ASR/YuanQI 打造自己的AI助手 页面数据渲染篇
杨不易呀
2024/06/24
3931
衔接-玩转AI新声态 | 玩转TTS/ASR/YuanQI 打造自己的AI助手
每日分享html之2个悬停、2个加载、1个button
1.前端工程师主要利用HMTL与CSS建构页面(其中html构建骨架,css构建样式),用JavaScript获取后端数据以及完善交互以及用户体验。 2.通俗来讲,前端在一个项目里,拿到UI设计师设计的设计稿,然后实现UI设计师设计稿,调用后端程序员给的数据接口以获取数据,然后测试,最后部署上线。 3.前端可以对设计图负责,大部分情况下,不需要特别的去理解业务逻辑,因为我们90后都是玩着十几年手机电脑长大的,十几年的经验足够我们在潜意识里想明白应该怎么做,怎么去一步步实现,会有什么意外情况。 4.我感觉前端发展有个很大的缺陷----晋升问题. 正如第三点所言,作为领导必须对项目有足够的了解,显然是要重点包括业务逻辑,这点上,后端开发者需要涉及数据库逻辑,是必须要跟业务逻辑打交道的(重中之重),因此,大部分的领导岗位都是后端开发者更有晋升的机会。当然,个别公司有专门的前端组长(这也不算什么),如果说前端开发者在自己工作范围之外还要腾出时间去研究业务逻辑,属实是觉得出力不讨好(因为这样的操作需要持续很久才能看出效果),而且再怎么研究业务逻辑也不会比每时每刻跟业务逻辑打交道的后端开发者了解更多。说实在的,大部分情况下,前端在配合后端进行开发.后端需要了解业务逻辑,要跟领导和客户商量细节,露脸机会很大,在老板面前刷脸次数众多。这些都是拉开前后端程序员晋升机会差距的因素。
淼学派对
2022/11/20
1.1K0
每日分享html之2个悬停、2个加载、1个button
相关推荐
卡片布局以及鼠标悬浮展示全部
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验