工作生活

css学习(例如选择器、keyframes实现原点、实现蒙版 )

2019-06-30  本文已影响0人  二营长家的张大炮

1.&
这是sass less中的语法 代表选择当前元素

2.nth-of-type
这个 CSS 伪类匹配文档树中在其之前具有 *a*n+*b*-1 个相同兄弟节点的元素,其中 n 为正值或零值。简单点说就是,这个选择器匹配那些在相同兄弟节点中的位置与模式 an+b 匹配的相同元素。

3.keyframes

.hasHand{
    opacity: 1;
    animation: show-hand 2s ease-in forwards;
}
.noHand{
    animation: hide-hand 2s ease-out forwards;
}
@keyframes show-hand{
    0%{
        opacity: 0;
        color: aquamarine
    }
    50%{
        opacity: .5;
        color: yellow;
    }
    100%{
        opacity: 1;
        color: tomato
    }
}
@keyframes hide-hand{
    0%{
        opacity: 1;
        color: aquamarine
    }
    50%{
        opacity: .5;
        color: blanchedalmond
    }
    100%{
        opacity: 0;
        color: cornsilk
    }
}

react官方推荐动画库

react-transition-group
image.png
.boxtext-enter {
   opacity: 0;
}
.boxtext-enter-active {
   opacity: 1;
   transition: 2s ease-in;
}
.boxtext-enter-done {
   opacity: 1;
}
.boxtext-exit {
   opacity: 1;
}
.boxtext-exit-active {
   opacity: 0;
   transition: 2s ease-out;
}
.boxtext-exit-done {
   opacity: 0;
}
image.png
 <div class="circle"></div>

  .circle {
      position: absolute;
      margin: 52px 45px;
      width: 12px;
      height: 12px;
      background: #fff;
      border-radius: 50%;
      border: 1px solid #2090ff;
    }
    
    .circle:after {
      content: '';
      margin: 3px;
      display: table;
      width: 6px;
      height: 6px;
      background: #2090ff;
      border-radius: 50%;
    }
<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <meta http-equiv="X-UA-Compatible" content="ie=edge" />
    <title>Document</title>
    <style>
      .ball-wrapper {
        width: 100%;
        height: 400px;
        border-bottom: 1px solid #eee;
        box-shadow: 0 10px 40px 0 rgba(0, 0, 0, 0.5);
        display: flex;
        flex-direction: column;
        justify-content: flex-end;
      }
      .ball {
        margin-bottom: 300px;
        width: 100px;
        height: 100px;
        border-radius: 50%; /* 把正方形变成圆形*/
        background-color: #ff5722; /* 设置颜色为橙色*/
        /* 
         这里用数字创建一个(慢,慢,慢,快)的曲线 – 
        */
        animation: bounce 0.5s cubic-bezier(0.5, 0.05, 1, 0.5);
        animation-direction: alternate;
        animation-iteration-count: infinite;
      }
      /* 
        使用关键字 @keyframes,在后面跟动画名称
        在 Keyframe 中,用 from 和 to 关键字来指定动画开始点和结尾点的 CSS 样式。
        我们使用 transform 让球沿着三维轴平移,translate3D 函数需要 3 个输入参数,即 (x, y, z) 。
         因为我们想让球上下跳动,我们只需要沿着 y 轴进行平移。因此,动画结束点(即 to 中样式)的 y 值变成了 300px 。
      */
      @keyframes bounce {
        from {
          transform: translate3d(0, 0, 0);
        }
        to {
          transform: translate3d(0, 300px, 0);
        }
      }
      /* 这里可以自定义动画名 */
      @keyframes mykeyframes {
        0% {
          left: 0px;
        }
        50% {
          left: 200px;
        }
        100% {
          left: 0;
        }
      }
      .square {
        position: absolute;
        width: 60px;
        height: 60px;
        background: #06a5ff;
        animation: mykeyframes 3s cubic-bezier(0.8, 0.04, 0.83, 0.67) infinite;
      }
      .yuandian {
        position: relative;
        width: 16px;
        height: 16px;
        border-radius: 50%;
        border: 1px solid #06a5ff;
        background: #fff;
      }

      .yuandian::after {
        content: "";
        position: absolute;
        top: 4px;
        left: 4px;
        width: 8px;
        height: 8px;
        border-radius: 50%;
        background: #06a5ff;
      }
    </style>
  </head>
  <body>
    <div class="ball-wrapper">
      <div class="ball"></div>
    </div>
    <div class="square"></div>
    <div class="yuandian"></div>
  </body>
</html>


image.png

@keyframes:https://www.cnblogs.com/yadiblogs/p/8460489.html
cubic-bezier:https://cubic-bezier.com/#.8,.04,.83,.67

4.实现蒙版

.mongolian-layer {
  margin-top: 25rpx;
  width: 29rpx;
  height: 35rpx;
  position: absolute;
  top: 0;
  left: 82%;
}

.hasshadow {
  background-image: linear-gradient(to right, rgba(255, 255, 255, 0.5), rgba(255, 255, 255, 1)); /* 标准的语法 */
}
image.png

5.vh vw


image.png

6.部分前端新特性

圆角-半径(border-radius:8px),
阴影(box-shadow:10px),
文字特效(text-shadow、),
线性渐变(gradient),
旋转(transform)
transform:rotate(9deg) scale(0.85,0.90) translate(0px,-30px) skew(-9deg,0deg);//旋转,缩放,定位,倾斜
增加了更多的CSS选择器
多背景 rgba

7.常见的兼容性问题

(1)png24位的图片在iE6浏览器上出现背景,解决方案是做成PNG8。
(2)浏览器默认的margin和padding不同。解决方案是加一个全局的*{margin:0;padding:0;}来统一。
(3)IE6双边距bug:块属性标签float后,又有横行的margin情况下,在ie6显示margin比设置的大。
(4)IE下,可以使用获取常规属性的方法来获取自定义属性,也可以使用getAttribute()获取自定义属性;
Firefox下,只能使用getAttribute()获取自定义属性;
解决方法:统一通过getAttribute()获取自定义属性。
(5)
IE下,even对象有x,y属性,但是没有pageX,pageY属性;
Firefox下,event对象有pageX,pageY属性,但是没有x,y属性;
解决方法:(条件注释)缺点是在IE浏览器下可能会增加额外的HTTP请求数。
(6)Chrome 中文界面下默认会将小于 12px 的文本强制按照 12px 显示,可通过加入 CSS 属性 -webkit-text-size-adjust: none; 解决。

8.实现放大缩小

<button class="button"></button>
<style type="text/css">
        .button{
            margin: 100px;
            width: 30px;
            height:30px;
            background: orange;
            border-radius: 50px;
            animation: flipping 5s infinite;

            /*去除button默认边框*/
            background-position-x: -7px;
            background-position-y: -7px;
            border: 1px;
            outline: none;
        }

        @keyframes flipping{
        0%{
            opacity: .2;
            transform: scale(1);
        }
        25%{
            opacity: 1;
            box-shadow:  0 0 15px orange;
            transform: scale(1.4);
        }
        50%{
            opacity: .2;
            transform: scale(1);
        }
        75%{
            opacity: 1;
            box-shadow:  0 0 15px orange;
            transform: scale(1.4);
        }
        100%{
            opacity: .2;
            transform: scale(1);
        }
    }
    </style>

涟漪扩散

 <div class="live">
         <img src="images/live.png" alt="">
         <span></span>
         <span></span>
     </div>
.live{
           position: relative;
           width: 100px;
           height: 100px;
       }
       .live img{
           width: 100px;
           height: 100px;
           z-index: 0;
       }
        @keyframes living {
            0%{
                transform: scale(1);
                opacity: 0.5;  
            }
            50%{
                transform: scale(1.5);  
                opacity: 0;   /*圆形放大的同时,透明度逐渐减小为0*/
            }
            100%{
                transform: scale(1);
                opacity: 0.5;
            }
        }
        .live span{
            position: absolute;
            width: 100px;
            height: 100px;
            left: 0;
            bottom: 0;
            background: #fff;
            border-radius: 50%;
            -webkit-animation: living 3s linear infinite;
            z-index: -1;
        }
        .live span:nth-child(2){
            -webkit-animation-delay: 1.5s; /*第二个span动画延迟1.5秒*/
        }

雷达

<div class="container">
    <div class="dot"></div>
    <div class="pulse p1"></div>
    <div class="pulse p2"></div>
</div>

.container {
position: relative;
}

.dot {
position: absolute;
width: 10px;
height: 10px;
left: 160px;
top: 160px;
border-radius: 50%;
border: 1px solid #33ccff;
background-color: #33ccff;
}

.pulse {
position: absolute;
width: 88px;
height: 88px;
left: 120px;
top: 120px;
border: 2px solid #3399ff;
border-radius: 50%;
opacity: 0; 
}

.p1 {
animation: warn 2s ease-out infinite;
}
.p2 {
animation: warn2 2s ease-out infinite;
}
/*.p1 {
animation: warn 2s ease-out infinite;
}
.p2 {
animation: warn 2s ease-out infinite;
-webkit-animation-delay: 1.5s;
}*/

@keyframes warn {
0% {transform: scale(0.3);opacity: 0.0;}

25% {transform: scale(0.3);opacity: 0.1;}

50% {transform: scale(0.5);opacity: 0.3;}

75% {transform: scale(0.8);opacity: 0.5;}

100% {transform: scale(1);opacity: 0.0;}
}

@keyframes warn2 {
0% {transform: scale(0.3);opacity: 0.0;}

25% {transform: scale(0.3);opacity: 0.1;}

50% {transform: scale(0.3);opacity: 0.3;}

75% {transform: scale(0.5);opacity: 0.5;}

100% {transform: scale(0.8);opacity: 0.0;}
}
上一篇 下一篇

猜你喜欢

热点阅读