引言

长久以来,我认识到。CSS,是存在极限的。正如曾经替你扛下一切的那个男人,也总有他眼含热泪地拼上一切,却也无法帮你做到的事情,他只能困窘地让你看到他的无能为力,怅然若失。 然后和曾经他成长的时代,做一一告别。
  • CSS有他难以做到的事情,我们帮他用lottie解决

  • CSS有他可以做到的事情,我们用我们的头脑帮他解决

本文实现的CSS效果一览

  • 标题吸顶

  • 手写箭头

  • 文字背景

  • 圆形天坑

  • 按钮波澜

  • 动态方形

  • 加载骨架

  • 多行省略

标题吸顶

sticky是一种和relative/fixed类似的定位方式,它可以实现这样的需求,就是一个标题栏nav,原本以普通默认的relative定位待在原位置,然后当页面向下滚动,当标题栏将要消失在窗口视野中时,它不但不跟随其他元素消失在窗口视野中,而是突然将定位方式变成fixed,显示成一直黏在窗口顶部的效果,就算鼠标再向下滚动,它也一直黏在那里。
这个效果实现,首先要通过position:sticky;设置成粘性定位,正如上面所说,它会在特定时候从relative转换为fixed,这个特定的时机由top/bottom等属性掌控,当元素距离小于top时候,便会触发,很显然,一般我们把top设置为0
.sticky {
    z-index: 100;
    width: 500px;
    height: 20px;
    background: red;
    position:sticky;
    position: -webkit-sticky;
    top:0px;
}

<div class="sticky" style="margin:30px;">
</div>
坑点:粘性定位生效的前提是,元素距离他的父元素顶部的距离要小于top,否则粘滞效果不起作用

手写箭头

我们一般会通过icon去实现一个箭头,可如果我们设置一点点难度:设计师如果不给你箭头Icon又改怎么办呢??我们可以这样:
  1. 先画一个div,border设置成箭头的颜色,同时呢,把div左边和下边的border变透明

  2. 再然后呢,把这个div右转45度:transform:rotate(45deg),这样就可以得到右边的箭头了

.arrow {
    width: 50px;
    height: 50px;
    border:10px solid blue;
    border-left-color: transparent;
    border-bottom-color: transparent;
    transform: rotate(45deg);
}

<div class="arrow" style="margin:30px"></div>

文字背景

  • A:CSS文字背景怎么实现?

  • B:我知道我知道!text-background

  • A: 你的猜测非常合理!但如果我们真有这个CSS属性就好了

对,问题在于我们没有text-background这样一个CSS属性实现文字背景,但是我们有background-clip: text;它可以把background按文本进行裁剪。裁剪之后呢,背景就只剩文本下面的这一块了,然后我们要注意,文本默认是不透明的呀,所以如果想要让人看到文本后面的背景,就要通过color:transparent将文本变成透明。
同时呢,我们有-webkit-background-clip可以特别针对webkit内核浏览器的实现,以进行兼容
body {
    background: #fff;
}
.text-bg {
    width: 800px;
    font-size: 70px;
    font-weight: bold;
    background: url(../demoImage/sea.jpg);
    background-clip: text;
    -webkit-background-clip: text;
    color: transparent;
    -webkit-text-fill-color: transparent;
}

<div class="text-bg" style="margin:30px">
  <p class="text">我叫彭湖湾,请叫我胖湾</p>
</div>

圆形天坑

在一些应用里,我们可能会看到有些用圆坑(或者说曲线)作为背景,例如知乎手机版的后面的这个很明显就是一个圆的底部。
下面这个圆坑怎么实现它呢?其实也很简单,就是在一个外壳div里面,放一个比它本身还要大的圆,然后让这个圆实现居中就好了。
.hole-wrapper {
    overflow: hidden;
    position: relative;
    width: 300px;
    height: 70px;
    background: white;
}
.hole {
    border-radius: 50%;
    background: blue;
    position: absolute;
    bottom:0;
    left:50%;
    margin-left: -200px;
    width: 400px;
    height:400px;
}

<div class="hole-wrapper" style="margin:30px">
  <div class="hole">
  </div>
</div>
你可能会问,为什么我画的这个圆上面一部分也要截掉,只留下一个圆坑呢?像上面知乎案例的要求,就算不把圆坑上面部分截成平的也可以实现啊。这是因为,在实际需求中,设计给你的UI需求,不一定就是整个大圆的一部分,而是可能需要将圆div的底部和上面一个长div结合起来才能实现,这时候,顶部被“截平”的圆就具有了容易组合的灵活优势了

按钮波澜

比如一些UI框架,当点击按钮的时候会看到波澜,那么这个效果是怎么实现的呢?首先我们这样分析(下面用悬浮模拟点击,从而实现纯CSS的效果)
  • 波澜的轮廓是一个不断扩大的圆,我们联想到可以通过变化的transform:scale()控制大小的变化

  • 圆随着扩大越来颜色越淡直到消失,我们可以给他设置白色background,并且通过变化的opacity控制透明度的变化

  • 通过animation来控制每个阶段,圆的具体的大小和颜色浓淡变化

@keyframes wave{
    20% {
        transform: scale(0.2);
        opacity: 0.8;
    }
    40% {
        transform: scale(0.4);
        opacity: 0.6;
    }
    60% {
        transform: scale(0.6);
        opacity: 0.4;
    }
    80% {
        transform: scale(0.8);
        opacity: 0.2;
    }
    100% {
        transform: scale(1);
        opacity: 0;
    }
}
.button {
  overflow: hidden;
  position: relative;
  border:2px solid #fff;
  background:#2894FF;
  border-radius: 10px;
  width: 200px;
  height: 50px;
}

.wave {
    border-radius: 50%;
    position: absolute;
    top:50%;
    margin-top: -200px;
    left: 50%;
    margin-left: -200px;
    background: #fff;
    width: 400px;
    height: 400px;
    transform: scale(0.01);
    opacity: 0;
}
/* 悬浮替代点击 */
.button:hover .wave{
  animation: wave linear 1s;
}
<div class="button" style="margin:30px">
  <div class="wave"></div>
</div>

动态方形

  • A:你实现一个高度和宽度一样的正方形!

  • B:太简单了!不要耍我!我会width:20px;height:20px;

  • A:但是,我的要求是要随外部div的长度变化,而变化的正方形

  • B:还是太简单了,我会width:20%;height:20% 。。。。。(被打断)

  • A:但是!这个外部包裹的div可能是一个变化的长方形!而你还是要在里面实现一个宽高成比例变化的正方形!

  • B:喵喵喵???

如下所示
首先要和大家说,下面这种方法是无效的,曾有人建议使用calc方法传入width作为参数,调用后赋给height,但是这是没有用的,浏览器无法识别。
/* 不知道是哪个大猪蹄子想出来的运行不了的方法 */
div {
  width: 20%;
  height:calc(width)
}

我们的思路

这时候,我们需要一条关键的信息:padding-top/padding-bottom是参考父元素的宽度去计算,这难免让人感觉到有一点点惊讶,垂直方向的padding-top居然会依靠水平方向的福元素的width去计算。但事实确实如此。
接下来事情你一定知道了:我们用padding-top去模拟了height!!
.square-wrapper {
    display: flex;
    justify-content: center;
    align-items: center;
    border: 2px solid blue;
    width: 300px;
    height: 200px;
}

.square-wrapper:hover {
    transition:width 2s,height 2s;
    width: 400px;
    height: 300px;
}

.square {
    background: red;
    width: 25%;
    padding-top:25%;
}

<div class="square-wrapper" style="margin:30px">
        <div class="square"></div>
</div>

加载条

加载条,或者加载骨架(skeleton),是在网页加载的时候用到的,加载条可以说很简单,但是要实现得方便易维护却要花点心思,比如说有得时候,我们可能单独为它编写一个skeleton组件,并且判断当前数据还没取到时候,就返回这个组件。这样没什么问题,但是,如果我们能把这段逻辑全部搬到CSS中去完成呢?那不就更好了吗?
有一个叫做:empty的伪元素,可以定位“还没有任何内容”的标签,这样的话,我们可以在empty 伪元素的代码块里编写加载条。这样的话,就不用把加载条逻辑代码搬到JS中了,尽量减少了对关键的业务代码的侵入性
.content {
    width: 200px;
    height: 20px;
    background:red ;
}
.content:empty{
    background: grey
}

<div class="skeleton" style="margin:30px">
  <div class="content">我有文本内容呢</div>
  <div class="content"></div>
</div>

更多参考资料:使用CSS自定义属性构建骨架屏

怎么让加载条动起来

你也许对上面纯静态的加载条感到有些不悦,但是没关系,因为这个实现很简单,方法也很多很多,如果是我的话,我会采用类似上一节讲到的第一个动效去完成它

CSS动效集锦,视觉魔法的碰撞与融合(一)

单/多行省略

在处理单/多行文本时候,我们可能会需要对过多的文字做省略处理,并且在截断的文字的结尾留下“...”的样式,笔者过去有篇知乎的文章对此进行了详细的总结,大家可以查看下面给的链接
<div style='width:400px;
         height:70px;
         border:1px solid red;'>
        <p style='display: -webkit-box;
            -webkit-box-orient: vertical;
            -webkit-line-clamp: 2;
            overflow:hidden;'>
            这是一些文本这是一些文本这是一些文本这是一些文本这是一些文本
            这是一些文本这是一些文本这是一些文本这是一些文本这是一些文本
        </p>
</div>
更多关于单/多行省略的资料,可以看看我以前写的文章

【CSS/JS】如何实现单行/多行文本溢出的省略(...)--老司机绕过坑道的正确姿势​

总结和感悟

我想借文章标题和内容,去表达作为一个前端工程师,曾经深切感受的心境:
“这个特效我实现不了啊!怎么办!?”
如果看似用一个方式解决不了,那就换一个,我发现,有趣的CSS样式玩的就是视觉欺骗,实际的实现,和表面上看到的东西往往是不一样的,在经过多方的拼凑之后,它就用那种也许不太优雅,但是却行之有效的方式出现在我们眼前。

个人介绍

大家好! 我叫彭湖湾,CSS职业选手,18年中韩前端大师邀请赛垫底最后一名,JavaScript排位赛中国区广东分区前1600强,我擅长使用的英雄是React和Vue,快速响应从而给短时间内敌人造成大量伤害! 我喜欢使用的武器是Node.js,但是武艺不精经常误伤自己,我的口号是:“我是IE守护者,痛击我的队友,保护我的敌人! ” 9102年9月1日,我将在知乎前端职业联赛ZPL (Zhihu Pro League)上送上我的精彩表现,敬请期待!

CSS特效集锦:视觉魔法的碰撞与融合(二)的更多相关文章

  1. CSS动效集锦,视觉魔法的碰撞与融合(二)

    引言 长久以来,我认识到.CSS,是存在极限的.正如曾经替你扛下一切的那个男人,也总有他眼含热泪地拼上一切,却也无法帮你做到的事情,他只能困窘地让你看到他的无能为力,怅然若失. 然后和曾经他成长的时代 ...

  2. CSS动效集锦,视觉魔法的碰撞与融合(一)

    前言 在本文中我讲述了7种CSS的动效,它们也许看起来并不惊艳,但是我认为却足够传达本文的理念:编写一些特殊的CSS样式的时候需要不拘于常理,要用特殊的认识角度看待标签和样式属性,从而用「绕个弯」的方 ...

  3. CSS动效集锦,视觉魔法的碰撞与融合(三)

    本文讲述的原理和相关demo 扇形DIV的使用——实现雷达扫描图 DIV环形布局—实现loading圈 动画的向量合成—实现抛物线动画 无限滚动动画—实现跑马灯效果 perspective和trans ...

  4. CSS知识点集锦

      CSS知识点集锦 CreateTime--2016年9月29日09:43:10Author:Marydon UpdateTime--2017年3月21日08:03:13 2.CSS样式优先级问题 ...

  5. CSS创意与视觉表现

    视觉效果 CSS代码: .cover { padding: 36% 50%; background: linear-gradient(to right, white 50%, black calc(5 ...

  6. 关于视觉里程计以及VI融合的相关研究(长期更新)

    1. svo 源码:https://github.com/uzh-rpg/rpg_svo 国内对齐文章源码的研究: (1)冯斌: 对其代码重写 https://github.com/yueying/O ...

  7. CSS学习笔记——视觉格式化模型 visual formatting model

    CSS 视觉格式化模型(visual formatting model)是用来处理文档并将它显示在视觉媒体上的机制.他有一套既定的规则(也就是W3C规范),规定了浏览器该怎么处理每一个盒子.以下内容翻 ...

  8. CSS中的视觉格式化模型

    视觉格式化模型 1. 简介 在视觉格式化模型中,文档树中的每个元素都将会根据盒模型产生零到多个盒子.这些盒子的布局由如下因素决定: 盒子的尺寸和类型 定位策略(正常文档流,浮动或者绝对定位) 和文档树 ...

  9. 【前端知识体系-CSS相关】CSS特效实现之Transition和Transform对比

    CSS效果 1.使用div绘制图形(三角形)? <!DOCTYPE html> <html lang="en"> <head> <meta ...

随机推荐

  1. 一文搞懂 Prometheus 的直方图

    原文链接:一文搞懂 Prometheus 的直方图 Prometheus 中提供了四种指标类型(参考:Prometheus 的指标类型),其中直方图(Histogram)和摘要(Summary)是最复 ...

  2. redis实现排行榜

    1 前言 实现一个排版榜,我们通常想到的就是mysql的order by 简单粗暴就撸出来了.但是这样真的优雅吗? 数据库是系统的瓶颈,这是众所周知的.如果给你一张百万的表,让你排序做排行榜,花费的时 ...

  3. 使用sublime调试node.js

    安装node相关 从node官网下载node的安装文件,我下的版本是node-v0.10.22-x64.exe,安装完node,node相关工具应该都加都环境变量path中了. 命令行下安装node- ...

  4. MVP架构下解决 RxJava 自动解绑问题

    背景 MVP 模式下使用 RxJava 处理网络访问的回调,当数据返回时 Presenter 调用绑定的 View 的方法. 定义 BasePresenter 如下: public class Bas ...

  5. 主成分分析 Principle Component Analysis

    一.主要思想 利用正交变换把可能线性相关变量表示的观测数据,转换为由少数几个线性无关变量(主成分)表示的数据.(重构原始特征空间:线性降维) 要尽可能保留原始数据中的信息,两个思路:最大投影方差.最小 ...

  6. EVE-NG入门篇

    目录 一.EVE-NG配置要求 二.EVE-NG 安装 三.基于OVA的安装步骤 四.导入设备介绍 五.启动设备 六.与secure CRT关联 七.常见问题 一.EVE-NG配置要求 1.最低配置 ...

  7. Zabbix添加windows主机监控

    zabbix监控windows主机 1.官网下载zabbix的windows-agent(选择相应版本): https://www.zabbix.com/cn/download_agents 2.将下 ...

  8. 轻松pick移动开发第一篇,flex布局

    一.什么是flex布局 首先提问一个问题,一般童鞋都会让子元素水平居中,那么怎么让子元素垂直居中呢?这里就要用到我们的flex布局了. 1.flex 是 flexible Box 的缩写,意为&quo ...

  9. Leetcode之二分法专题-154. 寻找旋转排序数组中的最小值 II(Find Minimum in Rotated Sorted Array II)

    Leetcode之二分法专题-154. 寻找旋转排序数组中的最小值 II(Find Minimum in Rotated Sorted Array II) 假设按照升序排序的数组在预先未知的某个点上进 ...

  10. Windows GIT SSH 免密教程

    Windows GIT SSH 免密教程 安装git客户端,最新下载地址如下 https://github.com/git-for-windows/git/releases/download/v2.2 ...