CSS3常用动画效果合集(最全),前端开发还会吃香吗

/* 转入 */

.a-rotatein{-webkit-animation-name:rotatein;-moz-animation-name:rotatein;-ms-animation-name:rotatein;animation-name:rotatein;}

/* 转入-从左上 */

.a-rotateinLT{-webkit-animation-name:rotateinLT;-moz-animation-name:rotateinLT;-ms-animation-name:rotateinLT;animation-name:rotateinLT;}

/* 转入-从左下 */

.a-rotateinLB{-webkit-animation-name:rotateinLB;-moz-animation-name:rotateinLB;-ms-animation-name:rotateinLB;animation-name:rotateinLB;}

/* 转入-从右上 */

.a-rotateinRT{-webkit-animation-name:rotateinRT;-moz-animation-name:rotateinRT;-ms-animation-name:rotateinRT;animation-name:rotateinRT;}

/* 转入-从右下*/

.a-rotateinRB{-webkit-animation-name:rotateinRB;-moz-animation-name:rotateinRB;-ms-animation-name:rotateinRB;animation-name:rotateinRB;}

/* 转出 */

.a-rotateout{-webkit-animation-name:rotateout;-moz-animation-name:rotateout;-ms-animation-name:rotateout;animation-name:rotateout;}

/* 转出-向左上 */

.a-rotateoutLT{-webkit-animation-name:rotateoutLT;-moz-animation-name:rotateoutLT;-ms-animation-name:rotateoutLT;animation-name:rotateoutLT;}

/* 转出-向左下 */

.a-rotateoutLB{-webkit-animation-name:rotateoutLB;-moz-animation-name:rotateoutLB;-ms-animation-name:rotateoutLB;animation-name:rotateoutLB;}

/* 转出-向右上 */

.a-rotateoutRT{-webkit-animation-name:rotateoutRT;-moz-animation-name:rotateoutRT;-ms-animation-name:rotateoutRT;animation-name:rotateoutRT;}

/* 转出-向右下 */

.a-rotateoutRB{-webkit-animation-name:rotateoutRB;-moz-animation-name:rotateoutRB;-ms-animation-name:rotateoutRB;animation-name:rotateoutRB;}

/* 翻转 */

.a-flip{-webkit-animation-name:flip;-moz-animation-name:flip;-ms-animation-name:flip;animation-name:flip;}

/* 翻入-X轴 */

.a-flipinX{-webkit-animation-name:flipinX;-moz-animation-name:flipinX;-ms-animation-name:flipinX;animation-name:flipinX;}

/* 翻入-Y轴 */

.a-flipin,.a-flipinY{-webkit-animation-name:flipinY;-moz-animation-name:flipinY;-ms-animation-name:flipinY;animation-name:flipinY;}

/* 翻出-X轴 */

.a-flipoutX{-webkit-animation-name:flipoutX;-moz-animation-name:flipoutX;-ms-animation-name:flipoutX;animation-name:flipoutX;}

/* 翻出-Y轴 */

.a-flipout,.a-flipoutY{-webkit-animation-name:flipoutY;-moz-animation-name:flipoutY;-ms-animation-name:flipoutY;animation-name:flipoutY;}

/* 闪烁 */

.a-flash{-webkit-animation-name:flash;-moz-animation-name:flash;-ms-animation-name:flash;animation-name:flash;}

/* 震颤 */

.a-shake{-webkit-animation-name:shake;-moz-animation-name:shake;-ms-animation-name:shake;animation-name:shake;}

/* 摇摆 */

.a-swing{-webkit-animation-name:swing;-moz-animation-name:swing;-ms-animation-name:swing;animation-name:swing;}

/* 摇晃 */

.a-wobble{-webkit-animation-name:wobble;-moz-animation-name:wobble;-ms-animation-name:wobble;animation-name:wobble;}

/* 震铃 */

.a-ring{-webkit-animation-name:ring;-moz-animation-name:ring;-ms-animation-name:ring;animation-name:ring;}

/* define */

/* 淡入 */

@-webkit-keyframes fadein{

0%{opacity:0;}

100%{opacity:1;}

}

@-moz-keyframes fadein{

0%{opacity:0;}

100%{opacity:1;}

}

@-ms-keyframes fadein{

0%{opacity:0;}

100%{opacity:1;}

}

@keyframes fadein{

0%{opacity:0;}

100%{opacity:1;}

}

/* 淡入-从上 */

@-webkit-keyframes fadeinT{

0%{opacity:0;-webkit-transform:translateY(-100px);}

100%{opacity:1;-webkit-transform:translateY(0);}

}

@-moz-keyframes fadeinT{

0%{opacity:0;-moz-transform:translateY(-100px);}

100%{opacity:1;-moz-transform:translateY(0);}

}

@-ms-keyframes fadeinT{

0%{opacity:0;-ms-transform:translateY(-100px);}

100%{opacity:1;-ms-transform:translateY(0);}

}

@keyframes fadeinT{

0%{opacity:0;transform:translateY(-100px);}

100%{opacity:1;transform:translateY(0);}

}

/* 淡入-从右 */

@-webkit-keyframes fadeinR{

0%{opacity:0;-webkit-transform:translateX(100px);}

100%{opacity:1;-webkit-transform:translateX(0);}

}

@-moz-keyframes fadeinR{

0%{opacity:0;-moz-transform:translateX(100px);}

100%{opacity:1;-moz-transform:translateX(0);}

}

@-ms-keyframes fadeinR{

0%{opacity:0;-ms-transform:translateX(100px);}

100%{opacity:1;-ms-transform:translateX(0);}

}

@keyframes fadeinR{

0%{opacity:0;transform:translateX(100px);}

100%{opacity:1;transform:translateX(0);}

}

/* 淡入-从下 */

@-webkit-keyframes fadeinB{

0%{opacity:0;-webkit-transform:translateY(100px);}

100%{opacity:1;-webkit-transform:translateY(0);}

}

@-moz-keyframes fadeinB{

0%{opacity:0;-moz-transform:translateY(100px);}

100%{opacity:1;-moz-transform:translateY(0);}

}

@-ms-keyframes fadeinB{

0%{opacity:0;-ms-transform:translateY(100px);}

100%{opacity:1;-ms-transform:translateY(0);}

}

@keyframes fadeinB{

0%{opacity:0;transform:translateY(100px);}

100%{opacity:1;transform:translateY(0);}

}

/* 淡入-从左 */

@-webkit-keyframes fadeinL{

0%{opacity:0;-webkit-transform:translateX(-100px);}

100%{opacity:1;-webkit-transform:translateX(0);}

}

@-moz-keyframes fadeinL{

0%{opacity:0;-moz-transform:translateX(-100px);}

100%{opacity:1;-moz-transform:translateX(0);}

}

@-ms-keyframes fadeinL{

0%{opacity:0;-ms-transform:translateX(-100px);}

100%{opacity:1;-ms-transform:translateX(0);}

}

@keyframes fadeinL{

0%{opacity:0;transform:translateX(-100px);}

100%{opacity:1;transform:translateX(0);}

}

/* 淡出 */

@-webkit-keyframes fadeout{

0%{opacity:1;}

100%{opacity:0;}

}

@-moz-keyframes fadeout{

0%{opacity:1;}

100%{opacity:0;}

}

@-ms-keyframes fadeout{

0%{opacity:1;}

100%{opacity:0;}

}

@keyframes fadeout{

0%{opacity:1;}

100%{opacity:0;}

}

/* 淡出-向上 */

@-webkit-keyframes fadeoutT{

0%{opacity:1;-webkit-transform:translateY(0);}

100%{opacity:0;-webkit-transform:translateY(-100px);}

}

@-moz-keyframes fadeoutT{

0%{opacity:1;-moz-transform:translateY(0);}

100%{opacity:0;-moz-transform:translateY(-100px);}

}

@-ms-keyframes fadeoutT{

0%{opacity:1;-ms-transform:translateY(0);}

100%{opacity:0;-ms-transform:translateY(-100px);}

}

@keyframes fadeoutT{

0%{opacity:1;transform:translateY(0);}

100%{opacity:0;transform:translateY(-100px);}

}

/* 淡出-向右 */

@-webkit-keyframes fadeoutR{

0%{opacity:1;-webkit-transform:translateX(0);}

100%{opacity:0;-webkit-transform:translateX(100px);}

}

@-moz-keyframes fadeoutR{

0%{opacity:1;-moz-transform:translateX(0);}

100%{opacity:0;-moz-transform:translateX(100px);}

}

@-ms-keyframes fadeoutR{

0%{opacity:1;-ms-transform:translateX(0);}

100%{opacity:0;-ms-transform:translateX(100px);}

}

@keyframes fadeoutR{

0%{opacity:1;transform:translateX(0);}

100%{opacity:0;transform:translateX(100px);}

}

/* 淡出-向下 */

@-webkit-keyframes fadeoutB{

0%{opacity:1;-webkit-transform:translateY(0);}

100%{opacity:0;-webkit-transform:translateY(100px);}

}

@-moz-keyframes fadeoutB{

0%{opacity:1;-moz-transform:translateY(0);}

100%{opacity:0;-moz-transform:translateY(100px);}

}

@-ms-keyframes fadeoutB{

0%{opacity:1;-ms-transform:translateY(0);}

100%{opacity:0;-ms-transform:translateY(100px);}

}

@keyframes fadeoutB{

0%{opacity:1;transform:translateY(0);}

100%{opacity:0;transform:translateY(100px);}

}

/* 淡出-向左 */

@-webkit-keyframes fadeoutL{

0%{opacity:1;-webkit-transform:translateX(0);}

100%{opacity:0;-webkit-transform:translateX(-100px);}

}

@-moz-keyframes fadeoutL{

0%{opacity:1;-moz-transform:translateX(0);}

100%{opacity:0;-moz-transform:translateX(-100px);}

}

@-ms-keyframes fadeoutL{

0%{opacity:1;-ms-transform:translateX(0);}

100%{opacity:0;-ms-transform:translateX(-100px);}

}

@keyframes fadeoutL{

0%{opacity:1;transform:translateX(0);}

100%{opacity:0;transform:translateX(-100px);}

}

/* 弹跳 */

@-webkit-keyframes bounce{

0%,20%,50%,80%,100%{-webkit-transform:translateY(0);}

40%{-webkit-transform:translateY(-30px);}

60%{-webkit-transform:translateY(-15px);}

}

@-moz-keyframes bounce{

0%,20%,50%,80%,100%{-moz-transform:translateY(0);}

40%{-moz-transform:translateY(-30px);}

60%{-moz-transform:translateY(-15px);}

}

@-ms-keyframes bounce{

0%,20%,50%,80%,100%{-ms-transform:translateY(0);}

40%{-ms-transform:translateY(-30px);}

60%{-ms-transform:translateY(-15px);}

}

@keyframes bounce{

0%,20%,50%,80%,100%{transform:translateY(0);}

40%{transform:translateY(-30px);}

60%{transform:translateY(-15px);}

}

/* 弹入 */

@-webkit-keyframes bouncein{

0%{opacity:0;-webkit-transform:scale(0.3);}

50%{opacity:1;-webkit-transform:scale(1.05);}

70%{-webkit-transform:scale(0.9);}

100%{-webkit-transform:scale(1);}

}

@-moz-keyframes bouncein{

0%{opacity:0;-moz-transform:scale(0.3);}

50%{opacity:1;-moz-transform:scale(1.05);}

70%{-moz-transform:scale(0.9);}

100%{-moz-transform:scale(1);}

}

@-ms-keyframes bouncein{

0%{opacity:0;-ms-transform:scale(0.3);}

50%{opacity:1;-ms-transform:scale(1.05);}

70%{-ms-transform:scale(0.9);}

100%{-ms-transform:scale(1);}

}

@keyframes bouncein{

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

50%{opacity:1;transform:scale(1.05);}

70%{transform:scale(0.9);}

100%{transform:scale(1);}

}

/* 弹入-从上 */

@-webkit-keyframes bounceinT{

0%{opacity:0;-webkit-transform:translateY(-100px);}

60%{opacity:1;-webkit-transform:translateY(30px);}

80%{-webkit-transform:translateY(-10px);}

100%{-webkit-transform:translateY(0);}

}

@-moz-keyframes bounceinT{

0%{opacity:0;-moz-transform:translateY(-100px);}

60%{opacity:1;-moz-transform:translateY(30px);}

80%{-moz-transform:translateY(-10px);}

100%{-moz-transform:translateY(0);}

}

@-ms-keyframes bounceinT{

0%{opacity:0;-ms-transform:translateY(-100px);}

60%{opacity:1;-ms-transform:translateY(30px);}

80%{-ms-transform:translateY(-10px);}

100%{-ms-transform:translateY(0);}

}

@keyframes bounceinT{

0%{opacity:0;transform:translateY(-100px);}

60%{opacity:1;transform:translateY(30px);}

80%{transform:translateY(-10px);}

100%{transform:translateY(0);}

}

/* 弹入-从右 */

@-webkit-keyframes bounceinR{

0%{opacity:0;-webkit-transform:translateX(100px);}

60%{opacity:1;-webkit-transform:translateX(-30px);}

80%{-webkit-transform:translateX(10px);}

100%{-webkit-transform:translateX(0);}

}

@-moz-keyframes bounceinR{

0%{opacity:0;-moz-transform:translateX(100px);}

60%{opacity:1;-moz-transform:translateX(-30px);}

80%{-moz-transform:translateX(10px);}

100%{-moz-transform:translateX(0);}

}

@-ms-keyframes bounceinR{

0%{opacity:0;-ms-transform:translateX(100px);}

60%{opacity:1;-ms-transform:translateX(-30px);}

80%{-ms-transform:translateX(10px);}

100%{-ms-transform:translateX(0);}

}

@keyframes bounceinR{

0%{opacity:0;transform:translateX(100px);}

60%{opacity:1;transform:translateX(-30px);}

80%{transform:translateX(10px);}

100%{transform:translateX(0);}

}

/* 弹入-从下 */

@-webkit-keyframes bounceinB{

0%{opacity:0;-webkit-transform:translateY(100px);}

60%{opacity:1;-webkit-transform:translateY(-30px);}

80%{-webkit-transform:translateY(10px);}

100%{-webkit-transform:translateY(0);}

}

@-moz-keyframes bounceinB{

0%{opacity:0;-moz-transform:translateY(100px);}

60%{opacity:1;-moz-transform:translateY(-30px);}

80%{-moz-transform:translateY(10px);}

100%{-moz-transform:translateY(0);}

}

@-ms-keyframes bounceinB{

0%{opacity:0;-ms-transform:translateY(100px);}

60%{opacity:1;-ms-transform:translateY(-30px);}

80%{-ms-transform:translateY(10px);}

100%{-ms-transform:translateY(0);}

}

@keyframes bounceinB{

0%{opacity:0;transform:translateY(100px);}

60%{opacity:1;transform:translateY(-30px);}

80%{transform:translateY(10px);}

100%{transform:translateY(0);}

}

/* 弹入-从左 */

@-webkit-keyframes bounceinL{

0%{opacity:0;-webkit-transform:translateX(-100px);}

60%{opacity:1;-webkit-transform:translateX(30px);}

80%{-webkit-transform:translateX(-10px);}

100%{-webkit-transform:translateX(0);}

}

@-moz-keyframes bounceinL{

0%{opacity:0;-moz-transform:translateX(-100px);}

60%{opacity:1;-moz-transform:translateX(30px);}

80%{-moz-transform:translateX(-10px);}

100%{-moz-transform:translateX(0);}

}

@-ms-keyframes bounceinL{

0%{opacity:0;-ms-transform:translateX(-100px);}

60%{opacity:1;-ms-transform:translateX(30px);}

80%{-ms-transform:translateX(-10px);}

100%{-ms-transform:translateX(0);}

}

@keyframes bounceinL{

0%{opacity:0;transform:translateX(-100px);}

60%{opacity:1;transform:translateX(30px);}

80%{transform:translateX(-10px);}

100%{transform:translateX(0);}

}

/* 弹出 */

@-webkit-keyframes bounceout{

0%{-webkit-transform:scale(1);}

25%{-webkit-transform:scale(0.95);}

50%{opacity:1;-webkit-transform:scale(1.1);}

100%{opacity:0;-webkit-transform:scale(0.3);}

}

@-moz-keyframes bounceout{

0%{-moz-transform:scale(1);}

25%{-moz-transform:scale(0.95);}

50%{opacity:1;-moz-transform:scale(1.1);}

100%{opacity:0;-moz-transform:scale(0.3);}

}

@-ms-keyframes bounceout{

0%{-ms-transform:scale(1);}

25%{-ms-transform:scale(0.95);}

50%{opacity:1;-ms-transform:scale(1.1);}

100%{opacity:0;-ms-transform:scale(0.3);}

}

@keyframes bounceout{

0%{transform:scale(1);}

25%{transform:scale(0.95);}

50%{opacity:1;transform:scale(1.1);}

100%{opacity:0;transform:scale(0.3);}

}

/* 弹出-向上*/

@-webkit-keyframes bounceoutT{

0%{-webkit-transform:translateY(0);}

20%{opacity:1;-webkit-transform:translateY(20px);}

100%{opacity:0;-webkit-transform:translateY(-100px);}

}

@-moz-keyframes bounceoutT{

0%{-moz-transform:translateY(0);}

20%{opacity:1;-moz-transform:translateY(20px);}

100%{opacity:0;-moz-transform:translateY(-100px);}

}

@-ms-keyframes bounceoutT{

0%{-ms-transform:translateY(0);}

20%{opacity:1;-ms-transform:translateY(20px);}

100%{opacity:0;-ms-transform:translateY(-100px);}

}

@keyframes bounceoutT{

0%{transform:translateY(0);}

20%{opacity:1;transform:translateY(20px);}

100%{opacity:0;transform:translateY(-100px);}

}

/* 弹出-向右*/

@-webkit-keyframes bounceoutR{

0%{-webkit-transform:translateX(0);}

20%{opacity:1;-webkit-transform:translateX(-20px);}

100%{opacity:0;-webkit-transform:translateX(100px);}

}

@-moz-keyframes bounceoutR{

0%{-moz-transform:translateX(0);}

20%{opacity:1;-moz-transform:translateX(-20px);}

100%{opacity:0;-moz-transform:translateX(100px);}

}

@-ms-keyframes bounceoutR{

0%{-ms-transform:translateX(0);}

20%{opacity:1;-ms-transform:translateX(-20px);}

100%{opacity:0;-ms-transform:translateX(100px);}

}

@keyframes bounceoutR{

0%{transform:translateX(0);}

20%{opacity:1;transform:translateX(-20px);}

100%{opacity:0;transform:translateX(100px);}

}

/* 弹出-向下 */

@-webkit-keyframes bounceoutB{

0%{-webkit-transform:translateY(0);}

20%{opacity:1;-webkit-transform:translateY(-20px);}

100%{opacity:0;-webkit-transform:translateY(100px);}

}

@-moz-keyframes bounceoutB{

0%{-moz-transform:translateY(0);}

20%{opacity:1;-moz-transform:translateY(-20px);}

100%{opacity:0;-moz-transform:translateY(100px);}

}

@-ms-keyframes bounceoutB{

0%{-ms-transform:translateY(0);}

20%{opacity:1;-ms-transform:translateY(-20px);}

100%{opacity:0;-ms-transform:translateY(100px);}

}

@keyframes bounceoutB{

0%{transform:translateY(0);}

20%{opacity:1;transform:translateY(-20px);}

100%{opacity:0;transform:translateY(100px);}

}

/* 弹出-向左 */

@-webkit-keyframes bounceoutL{

0%{-webkit-transform:translateX(0);}

20%{opacity:1;-webkit-transform:translateX(20px);}

100%{opacity:0;-webkit-transform:translateX(-100px);}

}

@-moz-keyframes bounceoutL{

0%{-moz-transform:translateX(0);}

20%{opacity:1;-moz-transform:translateX(20px);}

100%{opacity:0;-moz-transform:translateX(-100px);}

}

@-ms-keyframes bounceoutL{

0%{-ms-transform:translateX(0);}

20%{opacity:1;-ms-transform:translateX(20px);}

100%{opacity:0;-ms-transform:translateX(-100px);}

}

@keyframes bounceoutL{

0%{transform:translateX(0);}

20%{opacity:1;transform:translateX(20px);}

100%{opacity:0;transform:translateX(-200px);}

}

/* 转入 */

@-webkit-keyframes rotatein{

0%{opacity:0;-webkit-transform:rotate(-200deg);}

100%{opacity:1;-webkit-transform:rotate(0);}

}

@-moz-keyframes rotatein{

0%{opacity:0;-moz-transform:rotate(-200deg);}

100%{opacity:1;-moz-transform:rotate(0);}

}

@-ms-keyframes rotatein{

0%{opacity:0;-ms-transform:rotate(-200deg);}

100%{opacity:1;-ms-transform:rotate(0);}

}

@keyframes rotatein{

0%{opacity:0;transform:rotate(-200deg);}

100%{opacity:1;transform:rotate(0);}

}

/* 转入-从左上 */

@-webkit-keyframes rotateinLT{

0%{-webkit-transform-origin:left bottom;-webkit-transform:rotate(-90deg);opacity:0;}

100%{-webkit-transform-origin:left bottom;-webkit-transform:rotate(0);opacity:1;}

}

@-moz-keyframes rotateinLT{

0%{-moz-transform-origin:left bottom;-moz-transform:rotate(-90deg);opacity:0;}

100%{-moz-transform-origin:left bottom;-moz-transform:rotate(0);opacity:1;}

}

@-ms-keyframes rotateinLT{

0%{-ms-transform-origin:left bottom;-ms-transform:rotate(-90deg);opacity:0;}

100%{-ms-transform-origin:left bottom;-ms-transform:rotate(0);opacity:1;}

}

@keyframes rotateinLT{

0%{transform-origin:left bottom;transform:rotate(-90deg);opacity:0;}

100%{transform-origin:left bottom;transform:rotate(0);opacity:1;}

}

/* 转入-从左下 */

@-webkit-keyframes rotateineftB{

0%{-webkit-transform-origin:left bottom;-webkit-transform:rotate(90deg);opacity:0;}

100%{-webkit-transform-origin:left bottom;-webkit-transform:rotate(0);opacity:1;}

}

@-moz-keyframes rotateineftB{

0%{-moz-transform-origin:left bottom;-moz-transform:rotate(90deg);opacity:0;}

100%{-moz-transform-origin:left bottom;-moz-transform:rotate(0);opacity:1;}

}

@-ms-keyframes rotateineftB{

0%{-ms-transform-origin:left bottom;-ms-transform:rotate(90deg);opacity:0;}

100%{-ms-transform-origin:left bottom;-ms-transform:rotate(0);opacity:1;}

}

@keyframes rotateineftB{

0%{transform-origin:left bottom;transform:rotate(90deg);opacity:0;}

100%{transform-origin:left bottom;transform:rotate(0);opacity:1;}

}

/* 转入-从右上 */

@-webkit-keyframes rotateinRT{

0%{-webkit-transform-origin:right bottom;-webkit-transform:rotate(90deg);opacity:0;}

100%{-webkit-transform-origin:right bottom;-webkit-transform:rotate(0);opacity:1;}

}

@-moz-keyframes rotateinRT{

0%{-moz-transform-origin:right bottom;-moz-transform:rotate(90deg);opacity:0;}

100%{-moz-transform-origin:right bottom;-moz-transform:rotate(0);opacity:1;}

}

@-ms-keyframes rotateinRT{

0%{-ms-transform-origin:right bottom;-ms-transform:rotate(90deg);opacity:0;}

100%{-ms-transform-origin:right bottom;-ms-transform:rotate(0);opacity:1;}

}

@keyframes rotateinRT{

0%{transform-origin:right bottom;transform:rotate(90deg);opacity:0;}

100%{transform-origin:right bottom;transform:rotate(0);opacity:1;}

}

/* 转入-从右下*/

@-webkit-keyframes rotateinRB{

0%{-webkit-transform-origin:right bottom;-webkit-transform:rotate(-90deg);opacity:0;}

100%{-webkit-transform-origin:right bottom;-webkit-transform:rotate(0);opacity:1;}

}

@-moz-keyframes rotateinRB{

0%{-moz-transform-origin:right bottom;-moz-transform:rotate(-90deg);opacity:0;}

100%{-moz-transform-origin:right bottom;-moz-transform:rotate(0);opacity:1;}

}

@-ms-keyframes rotateinRB{

0%{-ms-transform-origin:right bottom;-ms-transform:rotate(-90deg);opacity:0;}

100%{-ms-transform-origin:right bottom;-ms-transform:rotate(0);opacity:1;}

}

@keyframes rotateinRB{

0%{transform-origin:right bottom;transform:rotate(-90deg);opacity:0;}

100%{transform-origin:right bottom;transform:rotate(0);opacity:1;}

}

/* 转出 */

@-webkit-keyframes rotateout{

0%{-webkit-transform-origin:center center;-webkit-transform:rotate(0);opacity:1;}

100%{-webkit-transform-origin:center center;-webkit-transform:rotate(200deg);opacity:0;}

}

@-moz-keyframes rotateout{

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数前端工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Web前端开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
img
img
img
img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上前端开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新

如果你觉得这些内容对你有帮助,可以添加V获取:vip1024c (备注前端)
img

这里分享一份由字节前端面试官整理的「2021大厂前端面试手册」,内容囊括Html、CSS、Javascript、Vue、HTTP、浏览器面试题、数据结构与算法。全部整理在下方文档中,共计111道

HTML

  • HTML5有哪些新特性?

  • Doctype作⽤? 严格模式与混杂模式如何区分?它们有何意义?

  • 如何实现浏览器内多个标签页之间的通信?

  • ⾏内元素有哪些?块级元素有哪些? 空(void)元素有那些?⾏内元 素和块级元素有什么区别?

  • 简述⼀下src与href的区别?

  • cookies,sessionStorage,localStorage 的区别?

  • HTML5 的离线储存的使用和原理?

  • 怎样处理 移动端 1px 被 渲染成 2px 问题?

  • iframe 的优缺点?

  • Canvas 和 SVG 图形的区别是什么?

JavaScript

CodeChina开源项目:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】

  • 问:0.1 + 0.2 === 0.3 嘛?为什么?

  • JS 数据类型

  • 写代码:实现函数能够深度克隆基本类型

  • 事件流

  • 事件是如何实现的?

  • new 一个函数发生了什么

  • 什么是作用域?

  • JS 隐式转换,显示转换

  • 了解 this 嘛,bind,call,apply 具体指什么

  • 手写 bind、apply、call

  • setTimeout(fn, 0)多久才执行,Event Loop

  • 手写题:Promise 原理

  • 说一下原型链和原型链的继承吧

  • 数组能够调用的函数有那些?

  • PWA使用过吗?serviceWorker的使用原理是啥?

  • ES6 之前使用 prototype 实现继承

  • 箭头函数和普通函数有啥区别?箭头函数能当构造函数吗?

  • 事件循环机制 (Event Loop)


前端)**
[外链图片转存中…(img-es7Lq7W9-1711900177102)]

这里分享一份由字节前端面试官整理的「2021大厂前端面试手册」,内容囊括Html、CSS、Javascript、Vue、HTTP、浏览器面试题、数据结构与算法。全部整理在下方文档中,共计111道

HTML

  • HTML5有哪些新特性?

  • Doctype作⽤? 严格模式与混杂模式如何区分?它们有何意义?

  • 如何实现浏览器内多个标签页之间的通信?

  • ⾏内元素有哪些?块级元素有哪些? 空(void)元素有那些?⾏内元 素和块级元素有什么区别?

  • 简述⼀下src与href的区别?

  • cookies,sessionStorage,localStorage 的区别?

  • HTML5 的离线储存的使用和原理?

  • 怎样处理 移动端 1px 被 渲染成 2px 问题?

  • iframe 的优缺点?

  • Canvas 和 SVG 图形的区别是什么?

JavaScript

CodeChina开源项目:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】

  • 问:0.1 + 0.2 === 0.3 嘛?为什么?

  • JS 数据类型

  • 写代码:实现函数能够深度克隆基本类型

  • 事件流

  • 事件是如何实现的?

  • new 一个函数发生了什么

  • 什么是作用域?

  • JS 隐式转换,显示转换

  • 了解 this 嘛,bind,call,apply 具体指什么

  • 手写 bind、apply、call

  • setTimeout(fn, 0)多久才执行,Event Loop

  • 手写题:Promise 原理

  • 说一下原型链和原型链的继承吧

  • 数组能够调用的函数有那些?

  • PWA使用过吗?serviceWorker的使用原理是啥?

  • ES6 之前使用 prototype 实现继承

  • 箭头函数和普通函数有啥区别?箭头函数能当构造函数吗?

  • 事件循环机制 (Event Loop)

  • 27
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值