最新公告
  • 欢迎您光临起源地模板网,本站秉承服务宗旨 履行“站长”责任,销售只是起点 服务永无止境!立即加入钻石VIP
  • 纯CSS实现常见的UI效果

    正文概述 掘金(alphardex)   2021-01-06   479

    前言

    大家好,这里是CSS魔法使——alphardex。

    切图仔,是大多数前端用来自嘲的称呼。相信很多人平时写页面的时候,大部分时间是在切图和排图,如此往复。这里并不是要否定切图本身,而是在质疑:一直切图到底对自己的功力增长有何好处?想想UI丢给你一套好看的界面,你却只需一个img标签,或者一个background-image属性即可搞定了它,但日后某个地方需要调整某些外观(颜色、文字等),你还不是会让UI再修改之前的素材,然后替换上去完事?这样就完全受制于UI,而无法发挥自己的能动性。

    那么,如何打破这个僵局?很简单,如果你CSS玩的够溜,你就无需再进行那枯燥无比的切图工作,那些界面、元素都是通过你双手亲自缔造而成的,尽管创作它们可能会花一些功夫,但带来的回报也是巨大的,你不仅能够自由掌控你所创造出来的元素,而且能大幅提高自己的CSS功力。

    在此之前

    在用纯CSS实现这些效果之前,笔者先介绍几个常用的SCSS Mixin和一个得力武器,用它们来进行创作将会事半功倍

    覆盖 - cover

    @mixin cover($top: 0, $left: 0, $width: 100%, $height: 100%) {
      position: absolute;
      top: $top;
      left: $left;
      width: $width;
      height: $height;
    }
    

    当你想在原先元素的基础上再“复制”一个元素,并将其覆盖在它身上时,你将会用到它

    纯CSS实现常见的UI效果

    demo地址:Blob Button

    嵌入 - inset

    @mixin inset($inset: 0) {
      position: absolute;
      top: $inset;
      left: $inset;
      right: $inset;
      bottom: $inset;
    }
    

    同样地,这也是在原先元素基础上复制出一个元素,只不过这个元素位置和原先的元素相同,大小会基于原先的元素而增减。

    举个例子,倘若你想创建多个半径不同的同心圆,这个Mixin将会很有帮助

    aqua.css

    aqua.css是笔者开源的一个优雅的、轻量级的CSS框架。里面有很多常用的组件以及常用的样式类,用它来写CSS体验将会非常爽

    在codepen上,笔者准备了一个aqua.css模版,大家可以用它来进行CSS的创作

    常见UI效果

    条纹效果

    纯CSS实现常见的UI效果

    首先,我们要抓住“边框”这个词,如何创作出一个特殊的边框呢?如果一般的CSS属性实现不了的话,可以考虑用伪元素来实现,思路如下:在原先的元素下方创建一个有条纹背景的伪元素,并保证原先元素覆盖住它就行,这样就模拟了边框的效果。

    那么如何创建条纹背景呢?这里我们将使用repeating-linear-gradient来实现它

    <div class="card w-80">
      <div class="border-stripe rounded-xl">
        Lorem ipsum...
      </div>
    </div>
    
    .border-stripe {
      --stripe-width: 0.5rem;
      --stripe-deg: -45deg;
      --stripe-color-1: var(--grey-color-1);
      --stripe-offset-1: 2px;
      --stripe-color-2: var(--skin-color-2);
      --stripe-offset-2: 1rem;
      --stripe-radius: 15px;
      --stripe-inset: calc(var(--stripe-width) * -1);
    
      &::before {
        @include inset(var(--stripe-inset));
        content: "";
        z-index: -1;
        background: repeating-linear-gradient(
          var(--stripe-deg),
          var(--stripe-color-1) 0 var(--stripe-offset-1),
          var(--stripe-color-2) 0 var(--stripe-offset-2)
        );
        border-radius: var(--stripe-radius);
      }
    }
    

    为了保证复用性,这里将其抽象成了border-stripe类,里面的值都可以通过CSS变量来动态调节

    demo地址:Stripe Border

    光泽效果

    纯CSS实现常见的UI效果

    一看到光泽,相信你可能会想到一个关键角色——径向渐变,通过它,我们可以创作出放射状的图案,而光泽也恰好是放射状的,再根据背景可以叠加的特性,光泽效果就能轻松实现了

    <div class="flex flex-col space-y-4">
      <span class="btn btn-primary btn-round inline-flex">
        <span class="font-bold text-grad">Shine Button 1</span>
      </span>
      <span class="btn btn-info btn-round btn-depth inline-flex">
        <span class="font-bold">Shine Button 2</span>
      </span>
    </div>
    
    :root {
      --blue-color-1: #08123d;
      --gold-color-1: #dcb687;
      --brown-color-1: #50301f;
      --brown-color-2: #936237;
      --gold-grad-1: radial-gradient(
          circle at 50% 5%,
          #{transparentize(white, 0.5)},
          #eba262
        ),
        #eba262;
      --gold-grad-2: linear-gradient(88deg, #e7924e 0%, #f8ffee 50%, #e7924e 100%);
      --blue-grad-1: radial-gradient(
          circle at 50% 5%,
          #{transparentize(white, 0.8)},
          #091344
        ),
        #091344;
      --primary-color: var(--blue-grad-1);
      --info-color: var(--gold-grad-1);
    }
    
    .btn {
      &-primary {
        border: 4px solid var(--gold-color-1);
    
        span {
          background-image: var(--gold-grad-2);
        }
      }
    
      &-info {
        color: var(--brown-color-1);
        border: none;
      }
    
      &-depth {
        box-shadow: 0 -5px 0 var(--brown-color-2);
      }
    }
    

    demo地址:Shine Button

    不规则形状

    纯CSS实现常见的UI效果

    首先,让我们先观察一下上图的缎带形状是由哪些基本形状组成的:中间是一个矩形,矩形下方有2个三角形,左右2侧各有一个被裁切过的矩形。一提裁切,就能想到clip-path这个属性,于是问题也就很好解决了

    <div class="ribbon">
      Pure CSS Ribbon
      <div class="block"></div>
      <div class="block"></div>
      <div class="block"></div>
      <div class="block"></div>
    </div>
    
    .ribbon {
      --ribbon-color-1: var(--yellow-color-1);
      --ribbon-color-2: var(--yellow-color-2);
      --ribbon-color-3: var(--yellow-color-3);
    
      position: relative;
      padding: 0.5rem 1rem;
      color: white;
      background: var(--ribbon-color-1);
    
      .block {
        &:nth-child(1),
        &:nth-child(2) {
          position: absolute;
          bottom: -20%;
          width: 20%;
          height: 20%;
          background: var(--ribbon-color-2);
          clip-path: polygon(0 0, 100% 100%, 100% 0);
        }
    
        &:nth-child(1) {
          left: 0;
        }
    
        &:nth-child(2) {
          right: 0;
          transform: scaleX(-1);
        }
    
        &:nth-child(3),
        &:nth-child(4) {
          position: absolute;
          z-index: -1;
          top: 20%;
          width: 40%;
          height: 100%;
          background: var(--ribbon-color-3);
          clip-path: polygon(0 0, 25% 50%, 0 100%, 100% 100%, 100% 0);
        }
    
        &:nth-child(3) {
          left: -20%;
        }
    
        &:nth-child(4) {
          right: -20%;
          transform: scaleX(-1);
        }
      }
    }
    

    注意到有一行代码transform: scaleX(-1);,这起到了水平翻转的作用,它可以防止再写一遍clip-path

    demo地址:Ribbon

    浮雕效果

    纯CSS实现常见的UI效果

    通过仔细观察,你会发现这是由2个同心的元素组成的,于是自然就想到了inset这个Mixin。

    创建了2个同心元素后,就要想办法来创建它们的浮雕光泽了。这里的光泽可以用box-shadow来实现,通过叠加多重阴影,我们就能模拟出浮雕的效果了

    <div class="px-6 py-2 text-xl embossed cursor-pointer" data-text="浮雕按钮" style="--emboss-radius: 1.5rem">
      浮雕按钮
    </div>
    
    :root {
      --red-color-1: #af2222;
      --red-color-2: #c1423e;
      --red-color-3: #c62a2a;
      --red-color-4: #951110;
      --green-color-1: #486433;
      --green-color-2: #2b361a;
      --red-grad-1: linear-gradient(
        to right,
        var(--red-color-1) 50%,
        var(--red-color-2) 0
      );
    }
    
    .embossed {
      --emboss-radius: 1rem;
      --emboss-out: 6px;
      --emboss-out-minus: calc(var(--emboss-out) * -1);
      --emboss-inset: 2px;
      --emboss-inset-minus: calc(var(--emboss-inset) * -1);
      --emboss-blur: 1px;
      --emboss-bg-1: var(--red-color-3);
      --emboss-bg-2: var(--green-color-1);
      --emboss-color-1: white;
      --emboss-color-2: var(--red-color-4);
      --emboss-color-3: var(--green-color-2);
    
      position: relative;
      box-sizing: border-box;
      white-space: nowrap;
    
      &::before {
        @include inset(var(--emboss-out-minus));
        content: "";
        background: var(--emboss-bg-1);
        box-shadow: inset var(--emboss-inset-minus) var(--emboss-inset-minus)
            var(--emboss-blur) var(--emboss-color-1),
          inset var(--emboss-inset) var(--emboss-inset) var(--emboss-blur)
            var(--emboss-color-2);
        border-radius: calc(var(--emboss-radius) + var(--emboss-out));
      }
    
      &::after {
        @include inset;
        @include flex-center;
        content: attr(data-text);
        color: white;
        font-weight: bold;
        background: var(--emboss-bg-2);
        box-shadow: inset var(--emboss-inset) var(--emboss-inset) var(--emboss-blur)
            var(--emboss-color-1),
          inset var(--emboss-inset-minus) var(--emboss-inset-minus)
            var(--emboss-blur) var(--emboss-color-3);
        border-radius: var(--emboss-radius);
      }
    }
    

    demo地址:Emboss Button

    课后作业

    尝试用纯CSS来实现下图的效果,不准切图哦~

    纯CSS实现常见的UI效果

    我的方案:做完再点哦


    起源地下载网 » 纯CSS实现常见的UI效果

    常见问题FAQ

    免费下载或者VIP会员专享资源能否直接商用?
    本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
    提示下载完但解压或打开不了?
    最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言,或 联络我们.。
    找不到素材资源介绍文章里的示例图片?
    对于PPT,KEY,Mockups,APP,网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
    模板不会安装或需要功能定制以及二次开发?
    请QQ联系我们

    发表评论

    还没有评论,快来抢沙发吧!

    如需帝国cms功能定制以及二次开发请联系我们

    联系作者

    请选择支付方式

    ×
    迅虎支付宝
    迅虎微信
    支付宝当面付
    余额支付
    ×
    微信扫码支付 0 元