This post contains a total of 7+ JavaScript Text Glitch Effect Examples with Source Code. All these Text Glitch Effects are made using JavaScript & Styled using CSS.
You can use the source code of these examples with credits to the original owner.
Related Posts
JavaScript Text Glitch Effect Examples
1. Multiple Glitch Effect
Made by Rasmus Bihl Andersson. Source
<!DOCTYPE html>
<html lang="en" >
<head>
<title></title>
<link rel='stylesheet' href='https://fonts.googleapis.com/css?family=Titillium+Web:400,900'>
<style>
.glitch--style-1 {
--gap-horizontal: 20px;
--gap-vertical: 2px;
--time-anim: 2.25s;
--blend-mode-1: none;
--blend-mode-2: none;
--blend-mode-3: none;
--blend-mode-4: none;
--blend-mode-5: none;
--blend-color-1: transparent;
--blend-color-2: transparent;
--blend-color-3: transparent;
--blend-color-4: transparent;
--blend-color-5: transparent;
}
.glitch--style-2 {
--gap-horizontal: 5px;
--gap-vertical: 10px;
--time-anim: 2s;
--blend-mode-1: none;
--blend-mode-2: none;
--blend-mode-3: luminosity;
--blend-mode-4: none;
--blend-mode-5: none;
--blend-color-1: transparent;
--blend-color-2: transparent;
--blend-color-3: #4d8c60;
--blend-color-4: transparent;
--blend-color-5: #c9b09a;
}
.glitch--style-3 {
--gap-horizontal: 20px;
--gap-vertical: 2px;
--time-anim: 2.25s;
--blend-mode-1: none;
--blend-mode-2: none;
--blend-mode-3: multiply;
--blend-mode-4: none;
--blend-mode-5: none;
--blend-color-1: transparent;
--blend-color-2: transparent;
--blend-color-3: #af4563;
--blend-color-4: transparent;
--blend-color-5: transparent;
}
.glitch--style-4 {
--gap-horizontal: 5px;
--gap-vertical: 20px;
--time-anim: 5s;
--blend-mode-1: none;
--blend-mode-2: exclusion;
--blend-mode-3: hard-light;
--blend-mode-4: overlay;
--blend-mode-5: none;
--blend-color-1: transparent;
--blend-color-2: #52f1cd;
--blend-color-3: #525df1;
--blend-color-4: #f19b52;
--blend-color-5: transparent;
}
.glitch--style-5 {
--gap-horizontal: 50px;
--gap-vertical: 100px;
--time-anim: 2.25s;
--blend-mode-1: none;
--blend-mode-2: none;
--blend-mode-3: none;
--blend-mode-4: overlay;
--blend-mode-5: overlay;
--blend-color-1: transparent;
--blend-color-2: transparent;
--blend-color-3: transparent;
--blend-color-4: #000;
--blend-color-5: #8d16f2;
}
.glitch--style-6 {
--gap-horizontal: 3px;
--gap-vertical: 70px;
--time-anim: 2.25s;
--blend-mode-1: none;
--blend-mode-2: none;
--blend-mode-3: overlay;
--blend-mode-4: none;
--blend-mode-5: none;
--blend-color-1: transparent;
--blend-color-2: transparent;
--blend-color-3: rgba(255,255,255,0.2);
--blend-color-4: transparent;
--blend-color-5: transparent;
}
.glitch {
position: relative;
display: inline-block;
margin: 0 0 8px;
overflow: hidden;
width: 95%;
}
.glitch:before, .glitch:after {
content: attr(data-text);
position: absolute;
width: 100%;
height: 100%;
background: #000000;
font: inherit;
visibility: hidden;
}
.glitch:before {
left: 2px;
text-shadow: -2px 0 #FF00F8;
clip: auto;
}
.glitch:after {
left: -2px;
text-shadow: -2px 0 #00D5FF;
clip: auto;
}
.glitch:before {
visibility: visible;
animation: glitch-anim-2 4s infinite linear alternate-reverse;
}
.glitch:after {
visibility: visible;
animation: glitch-anim 2.5s infinite linear alternate-reverse;
}
.glitch.style-2:before, .glitch.style-2:after {
animation-name: glitch-anim-2;
}
.glitch.style-1-hor:before, .glitch.style-1-hor:after {
animation-name: glitch-anim-1-horizontal;
}
.glitch.style-2-hor:before, .glitch.style-2-hor:after {
animation-name: glitch-anim-2-horizontal;
}
.glitch.style-3-hor:before, .glitch.style-3-hor:after {
animation-name: glitch-anim-3-horizontal;
}
.glitch.style-1-ver:before, .glitch.style-1-ver:after {
animation-name: glitch-anim-1-vertical;
}
.glitch.style-2-ver:before, .glitch.style-2-ver:after {
animation-name: glitch-anim-2-vertical;
}
.glitch.style-3-ver:before, .glitch.style-3-ver:after {
animation-name: glitch-anim-3-vertical;
}
.glitch.style-text:before, .glitch.style-text:after {
animation-name: glitch-anim-text;
}
.glitch.style-flash:before, .glitch.style-flash:after {
animation-name: glitch-anim-flash;
}
@keyframes glitch-anim {
0% {
clip: rect(29px, 9999px, 11px, 0);
}
4.16666667% {
clip: rect(11px, 9999px, 21px, 0);
}
8.33333333% {
clip: rect(18px, 9999px, 1px, 0);
}
12.5% {
clip: rect(17px, 9999px, 5px, 0);
}
16.66666667% {
clip: rect(3px, 9999px, 27px, 0);
}
20.83333333% {
clip: rect(20px, 9999px, 25px, 0);
}
25% {
clip: rect(25px, 9999px, 19px, 0);
}
29.16666667% {
clip: rect(12px, 9999px, 151px, 0);
}
33.33333333% {
clip: rect(29px, 9999px, 1px, 0);
}
37.5% {
clip: rect(24px, 9999px, 31px, 0);
}
41.66666667% {
clip: rect(9px, 9999px, 1px, 0);
}
45.83333333% {
clip: rect(1px, 9999px, 17px, 0);
}
50% {
clip: rect(3px, 9999px, 27px, 0);
}
54.16666667% {
clip: rect(17px, 9999px, 151px, 0);
}
58.33333333% {
clip: rect(15px, 9999px, 10px, 0);
}
62.5% {
clip: rect(1px, 9999px, 15px, 0);
}
66.66666667% {
clip: rect(10px, 9999px, 3px, 0);
}
70.83333333% {
clip: rect(27px, 9999px, 117px, 0);
}
75% {
clip: rect(2px, 9999px, 5px, 0);
}
79.16666667% {
clip: rect(4px, 9999px, 13px, 0);
}
83.33333333% {
clip: rect(8px, 9999px, 44px, 0);
}
87.5% {
clip: rect(13px, 9999px, 14px, 0);
}
91.66666667% {
clip: rect(21px, 9999px, 31px, 0);
}
95.83333333% {
clip: rect(0px, 9999px, 33px, 0);
}
100% {
clip: rect(9px, 9999px, 148px, 0);
}
}
@keyframes glitch-anim-2 {
6.66666667% {
clip: rect(43px, 9999px, 105px, 0);
}
10% {
clip: rect(5px, 9999px, 0px, 0);
}
13.33333333% {
clip: rect(16px, 9999px, 14px, 0);
}
16.66666667% {
clip: rect(12px, 9999px, 106px, 0);
}
20% {
clip: rect(1px, 9999px, 189px, 0);
}
23.33333333% {
clip: rect(20px, 9999px, 41px, 0);
}
26.66666667% {
clip: rect(30px, 9999px, 176px, 0);
}
30% {
clip: rect(12px, 9999px, 32px, 0);
}
33.33333333% {
clip: rect(22px, 9999px, 155px, 0);
}
36.66666667% {
clip: rect(14px, 9999px, 40px, 0);
}
40% {
clip: rect(25px, 9999px, 86px, 0);
}
43.33333333% {
clip: rect(13px, 9999px, 94px, 0);
}
46.66666667% {
clip: rect(1px, 9999px, 139px, 0);
}
50% {
clip: rect(14px, 9999px, 76px, 0);
}
53.33333333% {
clip: rect(2px, 9999px, 124px, 0);
}
56.66666667% {
clip: rect(6px, 9999px, 70px, 0);
}
60% {
clip: rect(9px, 9999px, 140px, 0);
}
63.33333333% {
clip: rect(7px, 9999px, 151px, 0);
}
66.66666667% {
clip: rect(1px, 9999px, 131px, 0);
}
70% {
clip: rect(21px, 9999px, 183px, 0);
}
73.33333333% {
clip: rect(11px, 9999px, 60px, 0);
}
76.66666667% {
clip: rect(91px, 9999px, 28px, 0);
}
80% {
clip: rect(14px, 9999px, 193px, 0);
}
83.33333333% {
clip: rect(2px, 9999px, 150px, 0);
}
86.66666667% {
clip: rect(3px, 9999px, 131px, 0);
}
90% {
clip: rect(17px, 9999px, 45px, 0);
}
93.33333333% {
clip: rect(18px, 9999px, 37px, 0);
}
96.66666667% {
clip: rect(9px, 9999px, 46px, 0);
}
100% {
clip: rect(38px, 9999px, 15px, 0);
}
}
/* Animations */
/* Horizontal */
@keyframes glitch-anim-1-horizontal {
0% {
-webkit-clip-path: polygon(0 2%, 100% 2%, 100% 5%, 0 5%);
clip-path: polygon(0 2%, 100% 2%, 100% 5%, 0 5%);
}
10% {
-webkit-clip-path: polygon(0 15%, 100% 15%, 100% 15%, 0 15%);
clip-path: polygon(0 15%, 100% 15%, 100% 15%, 0 15%);
}
20% {
-webkit-clip-path: polygon(0 10%, 100% 10%, 100% 20%, 0 20%);
clip-path: polygon(0 10%, 100% 10%, 100% 20%, 0 20%);
}
30% {
-webkit-clip-path: polygon(0 1%, 100% 1%, 100% 2%, 0 2%);
clip-path: polygon(0 1%, 100% 1%, 100% 2%, 0 2%);
}
40% {
-webkit-clip-path: polygon(0 33%, 100% 33%, 100% 33%, 0 33%);
clip-path: polygon(0 33%, 100% 33%, 100% 33%, 0 33%);
}
50% {
-webkit-clip-path: polygon(0 44%, 100% 44%, 100% 44%, 0 44%);
clip-path: polygon(0 44%, 100% 44%, 100% 44%, 0 44%);
}
60% {
-webkit-clip-path: polygon(0 50%, 100% 50%, 100% 20%, 0 20%);
clip-path: polygon(0 50%, 100% 50%, 100% 20%, 0 20%);
}
70% {
-webkit-clip-path: polygon(0 70%, 100% 70%, 100% 70%, 0 70%);
clip-path: polygon(0 70%, 100% 70%, 100% 70%, 0 70%);
}
80% {
-webkit-clip-path: polygon(0 80%, 100% 80%, 100% 80%, 0 80%);
clip-path: polygon(0 80%, 100% 80%, 100% 80%, 0 80%);
}
90% {
-webkit-clip-path: polygon(0 50%, 100% 50%, 100% 55%, 0 55%);
clip-path: polygon(0 50%, 100% 50%, 100% 55%, 0 55%);
}
100% {
-webkit-clip-path: polygon(0 70%, 100% 70%, 100% 80%, 0 80%);
clip-path: polygon(0 70%, 100% 70%, 100% 80%, 0 80%);
}
}
@keyframes glitch-anim-2-horizontal {
0% {
-webkit-clip-path: polygon(0 25%, 100% 25%, 100% 30%, 0 30%);
clip-path: polygon(0 25%, 100% 25%, 100% 30%, 0 30%);
}
15% {
-webkit-clip-path: polygon(0 3%, 100% 3%, 100% 3%, 0 3%);
clip-path: polygon(0 3%, 100% 3%, 100% 3%, 0 3%);
}
22% {
-webkit-clip-path: polygon(0 5%, 100% 5%, 100% 20%, 0 20%);
clip-path: polygon(0 5%, 100% 5%, 100% 20%, 0 20%);
}
31% {
-webkit-clip-path: polygon(0 20%, 100% 20%, 100% 20%, 0 20%);
clip-path: polygon(0 20%, 100% 20%, 100% 20%, 0 20%);
}
45% {
-webkit-clip-path: polygon(0 40%, 100% 40%, 100% 40%, 0 40%);
clip-path: polygon(0 40%, 100% 40%, 100% 40%, 0 40%);
}
51% {
-webkit-clip-path: polygon(0 52%, 100% 52%, 100% 59%, 0 59%);
clip-path: polygon(0 52%, 100% 52%, 100% 59%, 0 59%);
}
63% {
-webkit-clip-path: polygon(0 60%, 100% 60%, 100% 60%, 0 60%);
clip-path: polygon(0 60%, 100% 60%, 100% 60%, 0 60%);
}
76% {
-webkit-clip-path: polygon(0 75%, 100% 75%, 100% 75%, 0 75%);
clip-path: polygon(0 75%, 100% 75%, 100% 75%, 0 75%);
}
81% {
-webkit-clip-path: polygon(0 65%, 100% 65%, 100% 40%, 0 40%);
clip-path: polygon(0 65%, 100% 65%, 100% 40%, 0 40%);
}
94% {
-webkit-clip-path: polygon(0 45%, 100% 45%, 100% 50%, 0 50%);
clip-path: polygon(0 45%, 100% 45%, 100% 50%, 0 50%);
}
100% {
-webkit-clip-path: polygon(0 14%, 100% 14%, 100% 33%, 0 33%);
clip-path: polygon(0 14%, 100% 14%, 100% 33%, 0 33%);
}
}
@keyframes glitch-anim-3-horizontal {
0% {
-webkit-clip-path: polygon(0 1%, 100% 1%, 100% 3%, 0 3%);
clip-path: polygon(0 1%, 100% 1%, 100% 3%, 0 3%);
}
5% {
-webkit-clip-path: polygon(0 10%, 100% 10%, 100% 9%, 0 9%);
clip-path: polygon(0 10%, 100% 10%, 100% 9%, 0 9%);
}
10% {
-webkit-clip-path: polygon(0 5%, 100% 5%, 100% 6%, 0 6%);
clip-path: polygon(0 5%, 100% 5%, 100% 6%, 0 6%);
}
25% {
-webkit-clip-path: polygon(0 20%, 100% 20%, 100% 20%, 0 20%);
clip-path: polygon(0 20%, 100% 20%, 100% 20%, 0 20%);
}
27% {
-webkit-clip-path: polygon(0 10%, 100% 10%, 100% 10%, 0 10%);
clip-path: polygon(0 10%, 100% 10%, 100% 10%, 0 10%);
}
30% {
-webkit-clip-path: polygon(0 30%, 100% 30%, 100% 25%, 0 25%);
clip-path: polygon(0 30%, 100% 30%, 100% 25%, 0 25%);
}
33% {
-webkit-clip-path: polygon(0 15%, 100% 15%, 100% 16%, 0 16%);
clip-path: polygon(0 15%, 100% 15%, 100% 16%, 0 16%);
}
37% {
-webkit-clip-path: polygon(0 40%, 100% 40%, 100% 39%, 0 39%);
clip-path: polygon(0 40%, 100% 40%, 100% 39%, 0 39%);
}
40% {
-webkit-clip-path: polygon(0 20%, 100% 20%, 100% 21%, 0 21%);
clip-path: polygon(0 20%, 100% 20%, 100% 21%, 0 21%);
}
45% {
-webkit-clip-path: polygon(0 60%, 100% 60%, 100% 55%, 0 55%);
clip-path: polygon(0 60%, 100% 60%, 100% 55%, 0 55%);
}
50% {
-webkit-clip-path: polygon(0 30%, 100% 30%, 100% 31%, 0 31%);
clip-path: polygon(0 30%, 100% 30%, 100% 31%, 0 31%);
}
53% {
-webkit-clip-path: polygon(0 70%, 100% 70%, 100% 69%, 0 69%);
clip-path: polygon(0 70%, 100% 70%, 100% 69%, 0 69%);
}
57% {
-webkit-clip-path: polygon(0 40%, 100% 40%, 100% 41%, 0 41%);
clip-path: polygon(0 40%, 100% 40%, 100% 41%, 0 41%);
}
60% {
-webkit-clip-path: polygon(0 80%, 100% 80%, 100% 75%, 0 75%);
clip-path: polygon(0 80%, 100% 80%, 100% 75%, 0 75%);
}
65% {
-webkit-clip-path: polygon(0 50%, 100% 50%, 100% 51%, 0 51%);
clip-path: polygon(0 50%, 100% 50%, 100% 51%, 0 51%);
}
70% {
-webkit-clip-path: polygon(0 90%, 100% 90%, 100% 90%, 0 90%);
clip-path: polygon(0 90%, 100% 90%, 100% 90%, 0 90%);
}
73% {
-webkit-clip-path: polygon(0 60%, 100% 60%, 100% 60%, 0 60%);
clip-path: polygon(0 60%, 100% 60%, 100% 60%, 0 60%);
}
80% {
-webkit-clip-path: polygon(0 100%, 100% 100%, 100% 99%, 0 99%);
clip-path: polygon(0 100%, 100% 100%, 100% 99%, 0 99%);
}
100% {
-webkit-clip-path: polygon(0 70%, 100% 70%, 100% 71%, 0 71%);
clip-path: polygon(0 70%, 100% 70%, 100% 71%, 0 71%);
}
}
/* Vertical */
@keyframes glitch-anim-1-vertical {
0% {
-webkit-clip-path: polygon(2% 0, 5% 0, 5% 100%, 2% 100%);
clip-path: polygon(2% 0, 5% 0, 5% 100%, 2% 100%);
}
10% {
-webkit-clip-path: polygon(15% 0, 15% 0, 15% 100%, 15% 100%);
clip-path: polygon(15% 0, 15% 0, 15% 100%, 15% 100%);
}
20% {
-webkit-clip-path: polygon(10% 0, 20% 0, 20% 100%, 10% 100%);
clip-path: polygon(10% 0, 20% 0, 20% 100%, 10% 100%);
}
30% {
-webkit-clip-path: polygon(1% 0, 2% 0, 2% 100%, 1% 100%);
clip-path: polygon(1% 0, 2% 0, 2% 100%, 1% 100%);
}
40% {
-webkit-clip-path: polygon(33% 0, 33% 0, 33% 100%, 33% 100%);
clip-path: polygon(33% 0, 33% 0, 33% 100%, 33% 100%);
}
50% {
-webkit-clip-path: polygon(44% 0, 44% 0, 44% 100%, 44% 100%);
clip-path: polygon(44% 0, 44% 0, 44% 100%, 44% 100%);
}
60% {
-webkit-clip-path: polygon(50% 0, 20% 0, 20% 100%, 50% 100%);
clip-path: polygon(50% 0, 20% 0, 20% 100%, 50% 100%);
}
70% {
-webkit-clip-path: polygon(70% 0, 70% 0, 70% 100% 70%, 70% 100%);
clip-path: polygon(70% 0, 70% 0, 70% 100% 70%, 70% 100%);
}
80% {
-webkit-clip-path: polygon(80% 0, 80% 0, 80% 100% 80%, 80% 100%);
clip-path: polygon(80% 0, 80% 0, 80% 100% 80%, 80% 100%);
}
90% {
-webkit-clip-path: polygon(50% 0, 55% 0, 55% 100%, 50% 100%);
clip-path: polygon(50% 0, 55% 0, 55% 100%, 50% 100%);
}
100% {
-webkit-clip-path: polygon(70% 0, 80% 0, 80% 100%, 70% 100%);
clip-path: polygon(70% 0, 80% 0, 80% 100%, 70% 100%);
}
}
@keyframes glitch-anim-2-vertical {
0% {
-webkit-clip-path: polygon(25% 0, 30% 0, 30% 100%, 25% 100%);
clip-path: polygon(25% 0, 30% 0, 30% 100%, 25% 100%);
}
15% {
-webkit-clip-path: polygon(3% 0, 3% 0, 3% 100%, 3% 100%);
clip-path: polygon(3% 0, 3% 0, 3% 100%, 3% 100%);
}
22% {
-webkit-clip-path: polygon(5% 0, 20% 0, 20% 100%, 5% 100%);
clip-path: polygon(5% 0, 20% 0, 20% 100%, 5% 100%);
}
31% {
-webkit-clip-path: polygon(20% 0, 20% 0, 20% 100%, 20% 100%);
clip-path: polygon(20% 0, 20% 0, 20% 100%, 20% 100%);
}
45% {
-webkit-clip-path: polygon(40% 0, 40% 0, 40% 100%, 40% 100%);
clip-path: polygon(40% 0, 40% 0, 40% 100%, 40% 100%);
}
51% {
-webkit-clip-path: polygon(52% 0, 59% 0, 59% 100%, 52% 100%);
clip-path: polygon(52% 0, 59% 0, 59% 100%, 52% 100%);
}
63% {
-webkit-clip-path: polygon(60% 0, 60% 0, 60% 100%, 60% 100%);
clip-path: polygon(60% 0, 60% 0, 60% 100%, 60% 100%);
}
76% {
-webkit-clip-path: polygon(75% 0, 75% 0, 75% 100%, 75% 100%);
clip-path: polygon(75% 0, 75% 0, 75% 100%, 75% 100%);
}
81% {
-webkit-clip-path: polygon(65% 0, 40% 0, 40% 100%, 65% 100%);
clip-path: polygon(65% 0, 40% 0, 40% 100%, 65% 100%);
}
94% {
-webkit-clip-path: polygon(45% 0, 50% 0, 50% 100%, 45% 100%);
clip-path: polygon(45% 0, 50% 0, 50% 100%, 45% 100%);
}
100% {
-webkit-clip-path: polygon(14% 0, 33% 0, 33% 100%, 14% 100%);
clip-path: polygon(14% 0, 33% 0, 33% 100%, 14% 100%);
}
}
@keyframes glitch-anim-3-vertical {
0% {
-webkit-clip-path: polygon(1% 0, 3% 0, 3% 100%, 1% 100%);
clip-path: polygon(1% 0, 3% 0, 3% 100%, 1% 100%);
}
5% {
-webkit-clip-path: polygon(10% 0, 9% 0, 9% 100%, 10% 100%);
clip-path: polygon(10% 0, 9% 0, 9% 100%, 10% 100%);
}
10% {
-webkit-clip-path: polygon(5% 0, 6% 0 6% 100%, 5% 100%);
clip-path: polygon(5% 0, 6% 0 6% 100%, 5% 100%);
}
25% {
-webkit-clip-path: polygon(20% 0, 20% 0, 20% 100%, 20% 100%);
clip-path: polygon(20% 0, 20% 0, 20% 100%, 20% 100%);
}
27% {
-webkit-clip-path: polygon(10% 0, 10% 0, 10% 100%, 10% 100%);
clip-path: polygon(10% 0, 10% 0, 10% 100%, 10% 100%);
}
30% {
-webkit-clip-path: polygon(30% 0, 25% 0, 25% 100%, 30% 100%);
clip-path: polygon(30% 0, 25% 0, 25% 100%, 30% 100%);
}
33% {
-webkit-clip-path: polygon(15% 0, 16% 0, 16% 100%, 15% 100%);
clip-path: polygon(15% 0, 16% 0, 16% 100%, 15% 100%);
}
37% {
-webkit-clip-path: polygon(40% 0, 39% 0, 39% 100%, 40% 100%);
clip-path: polygon(40% 0, 39% 0, 39% 100%, 40% 100%);
}
40% {
-webkit-clip-path: polygon(20% 0, 21% 0, 21% 100%, 20% 100%);
clip-path: polygon(20% 0, 21% 0, 21% 100%, 20% 100%);
}
45% {
-webkit-clip-path: polygon(60% 0, 55% 0, 55% 100%, 60% 100%);
clip-path: polygon(60% 0, 55% 0, 55% 100%, 60% 100%);
}
50% {
-webkit-clip-path: polygon(30% 0, 31% 0, 31% 100%, 30% 100%);
clip-path: polygon(30% 0, 31% 0, 31% 100%, 30% 100%);
}
53% {
-webkit-clip-path: polygon(70% 0, 69% 0, 69% 100%, 70% 100%);
clip-path: polygon(70% 0, 69% 0, 69% 100%, 70% 100%);
}
57% {
-webkit-clip-path: polygon(40% 0, 41% 0, 41% 100%, 40% 100%);
clip-path: polygon(40% 0, 41% 0, 41% 100%, 40% 100%);
}
60% {
-webkit-clip-path: polygon(80% 0, 75% 0, 75% 100%, 80% 100%);
clip-path: polygon(80% 0, 75% 0, 75% 100%, 80% 100%);
}
65% {
-webkit-clip-path: polygon(50% 0, 51% 0, 51% 100%, 50% 100%);
clip-path: polygon(50% 0, 51% 0, 51% 100%, 50% 100%);
}
70% {
-webkit-clip-path: polygon(90% 0, 90% 0, 90% 100%, 90% 100%);
clip-path: polygon(90% 0, 90% 0, 90% 100%, 90% 100%);
}
73% {
-webkit-clip-path: polygon(60% 0, 60% 0, 60% 100%, 60% 100%);
clip-path: polygon(60% 0, 60% 0, 60% 100%, 60% 100%);
}
80% {
-webkit-clip-path: polygon(100% 0, 99% 0, 99% 100%, 100% 100%);
clip-path: polygon(100% 0, 99% 0, 99% 100%, 100% 100%);
}
100% {
-webkit-clip-path: polygon(70% 0, 71% 0, 71% 100%, 70% 100%);
clip-path: polygon(70% 0, 71% 0, 71% 100%, 70% 100%);
}
}
@keyframes glitch-anim-text {
0% {
opacity: 1;
transform: translate3d(-10px, 0, 0) scale3d(-1, -1, 1);
-webkit-clip-path: polygon(0 20%, 100% 20%, 100% 21%, 0 21%);
clip-path: polygon(0 20%, 100% 20%, 100% 21%, 0 21%);
}
10% {
-webkit-clip-path: polygon(0 33%, 100% 33%, 100% 33%, 0 33%);
clip-path: polygon(0 33%, 100% 33%, 100% 33%, 0 33%);
}
20% {
-webkit-clip-path: polygon(0 44%, 100% 44%, 100% 44%, 0 44%);
clip-path: polygon(0 44%, 100% 44%, 100% 44%, 0 44%);
}
35% {
-webkit-clip-path: polygon(0 50%, 100% 50%, 100% 20%, 0 20%);
clip-path: polygon(0 50%, 100% 50%, 100% 20%, 0 20%);
}
50% {
-webkit-clip-path: polygon(0 70%, 100% 70%, 100% 70%, 0 70%);
clip-path: polygon(0 70%, 100% 70%, 100% 70%, 0 70%);
}
60% {
-webkit-clip-path: polygon(0 80%, 100% 80%, 100% 80%, 0 80%);
clip-path: polygon(0 80%, 100% 80%, 100% 80%, 0 80%);
}
70% {
-webkit-clip-path: polygon(0 50%, 100% 50%, 100% 55%, 0 55%);
clip-path: polygon(0 50%, 100% 50%, 100% 55%, 0 55%);
}
80% {
-webkit-clip-path: polygon(0 70%, 100% 70%, 100% 80%, 0 80%);
clip-path: polygon(0 70%, 100% 70%, 100% 80%, 0 80%);
}
90% {
transform: translate3d(-10px, 0, 0) scale3d(-1, -1, 1);
}
100% {
opacity: 1;
transform: translate3d(0, 0, 0) scale3d(1, 1, 1);
-webkit-clip-path: polygon(0 0, 100% 0, 100% 100%, 0% 100%);
clip-path: polygon(0 0, 100% 0, 100% 100%, 0% 100%);
}
}
/* Flash */
@keyframes glitch-anim-flash {
0% {
opacity: 0.2;
transform: translate3d(var(--gap-horizontal), var(--gap-vertical), 0);
}
33%, 100% {
opacity: 0;
transform: translate3d(0, 0, 0);
}
}
body {
padding: 0;
margin: 0;
border: 0;
font-family: "Titillium Web", "Helvetica", sans-serif;
font-weight: 900;
text-transform: uppercase;
background-color: #000000;
display: flex;
color: #ffffff;
justify-content: center;
align-items: center;
width: 100vw;
height: 100vh;
text-align: center;
font-size: 10vw;
}
select {
position: fixed;
bottom: 25px;
left: 50%;
transform: translateX(-50%);
opacity: 0.2;
transition: 0.3s ease;
}
select:hover {
opacity: 1;
}
</style>
</head>
<body>
<span data-text="Glitch this!" class="glitch">
Glitch this!
</span>
<select id="styleswitch">
<option value="style-1">Style #1</option>
<option value="style-2">Style #2</option>
<option value="style-1-hor">Style Horizontal #1</option>
<option value="style-2-hor">Style Horizontal #2</option>
<option value="style-3-hor">Style Horizontal #3</option>
<option value="style-1-ver">Style Vertical #1</option>
<option value="style-2-ver">Style Vertical #2</option>
<option value="style-3-ver">Style Vertical #3</option>
<option value="style-text">Style Text</option>
<option value="style-flash">Style Flash</option>
</select>
<script src='https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js'></script>
<script>
//This just changes the style of the glitch
jQuery('#styleswitch').on('change', function () {
var gstyle = Math.floor(Math.random() * 5) + 1;
jQuery('.glitch').attr('class', 'glitch glitch--style-' + gstyle + ' ' + jQuery(this).val());
});
jQuery('#styleswitch').trigger('change');
//# sourceURL=pen.js
</script>
</body>
</html>
2. Word glitch
Made by Quentin. Source
<!DOCTYPE html>
<html lang="en" >
<head>
<title>h</title>
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/normalize/5.0.0/normalize.min.css">
<style>
body {
background: black;
}
.glitch {
color: white;
font-size: 100px;
position: relative;
width: 400px;
margin: 0 auto;
}
@-webkit-keyframes noise-anim {
0% {
clip: rect(43px, 9999px, 61px, 0);
}
5% {
clip: rect(95px, 9999px, 78px, 0);
}
10% {
clip: rect(64px, 9999px, 43px, 0);
}
15% {
clip: rect(18px, 9999px, 13px, 0);
}
20% {
clip: rect(53px, 9999px, 45px, 0);
}
25% {
clip: rect(28px, 9999px, 88px, 0);
}
30% {
clip: rect(38px, 9999px, 6px, 0);
}
35% {
clip: rect(68px, 9999px, 68px, 0);
}
40% {
clip: rect(60px, 9999px, 30px, 0);
}
45% {
clip: rect(41px, 9999px, 9px, 0);
}
50% {
clip: rect(29px, 9999px, 24px, 0);
}
55% {
clip: rect(13px, 9999px, 19px, 0);
}
60% {
clip: rect(86px, 9999px, 50px, 0);
}
65% {
clip: rect(16px, 9999px, 94px, 0);
}
70% {
clip: rect(2px, 9999px, 38px, 0);
}
75% {
clip: rect(67px, 9999px, 63px, 0);
}
80% {
clip: rect(21px, 9999px, 83px, 0);
}
85% {
clip: rect(85px, 9999px, 83px, 0);
}
90% {
clip: rect(81px, 9999px, 35px, 0);
}
95% {
clip: rect(94px, 9999px, 23px, 0);
}
100% {
clip: rect(81px, 9999px, 97px, 0);
}
}
@keyframes noise-anim {
0% {
clip: rect(43px, 9999px, 61px, 0);
}
5% {
clip: rect(95px, 9999px, 78px, 0);
}
10% {
clip: rect(64px, 9999px, 43px, 0);
}
15% {
clip: rect(18px, 9999px, 13px, 0);
}
20% {
clip: rect(53px, 9999px, 45px, 0);
}
25% {
clip: rect(28px, 9999px, 88px, 0);
}
30% {
clip: rect(38px, 9999px, 6px, 0);
}
35% {
clip: rect(68px, 9999px, 68px, 0);
}
40% {
clip: rect(60px, 9999px, 30px, 0);
}
45% {
clip: rect(41px, 9999px, 9px, 0);
}
50% {
clip: rect(29px, 9999px, 24px, 0);
}
55% {
clip: rect(13px, 9999px, 19px, 0);
}
60% {
clip: rect(86px, 9999px, 50px, 0);
}
65% {
clip: rect(16px, 9999px, 94px, 0);
}
70% {
clip: rect(2px, 9999px, 38px, 0);
}
75% {
clip: rect(67px, 9999px, 63px, 0);
}
80% {
clip: rect(21px, 9999px, 83px, 0);
}
85% {
clip: rect(85px, 9999px, 83px, 0);
}
90% {
clip: rect(81px, 9999px, 35px, 0);
}
95% {
clip: rect(94px, 9999px, 23px, 0);
}
100% {
clip: rect(81px, 9999px, 97px, 0);
}
}
.glitch:after {
content: attr(data-text);
position: absolute;
left: 2px;
text-shadow: -1px 0 red;
top: 0;
color: white;
background: black;
overflow: hidden;
clip: rect(0, 900px, 0, 0);
animation: noise-anim 2s infinite linear alternate-reverse;
}
@-webkit-keyframes noise-anim-2 {
0% {
clip: rect(24px, 9999px, 62px, 0);
}
5% {
clip: rect(42px, 9999px, 23px, 0);
}
10% {
clip: rect(10px, 9999px, 15px, 0);
}
15% {
clip: rect(5px, 9999px, 61px, 0);
}
20% {
clip: rect(40px, 9999px, 56px, 0);
}
25% {
clip: rect(74px, 9999px, 19px, 0);
}
30% {
clip: rect(32px, 9999px, 23px, 0);
}
35% {
clip: rect(12px, 9999px, 71px, 0);
}
40% {
clip: rect(38px, 9999px, 64px, 0);
}
45% {
clip: rect(87px, 9999px, 85px, 0);
}
50% {
clip: rect(33px, 9999px, 73px, 0);
}
55% {
clip: rect(10px, 9999px, 41px, 0);
}
60% {
clip: rect(57px, 9999px, 33px, 0);
}
65% {
clip: rect(46px, 9999px, 91px, 0);
}
70% {
clip: rect(78px, 9999px, 66px, 0);
}
75% {
clip: rect(19px, 9999px, 29px, 0);
}
80% {
clip: rect(55px, 9999px, 44px, 0);
}
85% {
clip: rect(96px, 9999px, 94px, 0);
}
90% {
clip: rect(5px, 9999px, 88px, 0);
}
95% {
clip: rect(14px, 9999px, 60px, 0);
}
100% {
clip: rect(88px, 9999px, 91px, 0);
}
}
@keyframes noise-anim-2 {
0% {
clip: rect(24px, 9999px, 62px, 0);
}
5% {
clip: rect(42px, 9999px, 23px, 0);
}
10% {
clip: rect(10px, 9999px, 15px, 0);
}
15% {
clip: rect(5px, 9999px, 61px, 0);
}
20% {
clip: rect(40px, 9999px, 56px, 0);
}
25% {
clip: rect(74px, 9999px, 19px, 0);
}
30% {
clip: rect(32px, 9999px, 23px, 0);
}
35% {
clip: rect(12px, 9999px, 71px, 0);
}
40% {
clip: rect(38px, 9999px, 64px, 0);
}
45% {
clip: rect(87px, 9999px, 85px, 0);
}
50% {
clip: rect(33px, 9999px, 73px, 0);
}
55% {
clip: rect(10px, 9999px, 41px, 0);
}
60% {
clip: rect(57px, 9999px, 33px, 0);
}
65% {
clip: rect(46px, 9999px, 91px, 0);
}
70% {
clip: rect(78px, 9999px, 66px, 0);
}
75% {
clip: rect(19px, 9999px, 29px, 0);
}
80% {
clip: rect(55px, 9999px, 44px, 0);
}
85% {
clip: rect(96px, 9999px, 94px, 0);
}
90% {
clip: rect(5px, 9999px, 88px, 0);
}
95% {
clip: rect(14px, 9999px, 60px, 0);
}
100% {
clip: rect(88px, 9999px, 91px, 0);
}
}
.glitch:before {
content: attr(data-text);
position: absolute;
left: -2px;
text-shadow: 1px 0 blue;
top: 0;
color: white;
background: black;
overflow: hidden;
clip: rect(0, 900px, 0, 0);
animation: noise-anim-2 3s infinite linear alternate-reverse;
}
.varela {
font-family: 'Varela', sans-serif;
}
.open {
font-family: 'Open Sans', sans-serif;
}
.oswald {
font-family: 'Oswald', sans-serif;
}
</style>
</head>
<body>
<link href='https://fonts.googleapis.com/css?family=Varela' rel='stylesheet' type='text/css'>
<link href='https://fonts.googleapis.com/css?family=Open+Sans' rel='stylesheet' type='text/css'>
<link href='https://fonts.googleapis.com/css?family=Oswald' rel='stylesheet' type='text/css'>
<div class="glitch" data-text="GLITCH">GLITCH</div>
<script src='//cdnjs.cloudflare.com/ajax/libs/jquery/2.2.2/jquery.min.js'></script>
<script>
class App {
constructor() {
this.$els = {
glitch: $('.glitch') };
this.fontFamily = ['varela', 'open', 'oswald'];
this.words = ['test', 'glitch', 'Quentin'];
}
glitch(delay) {
setInterval(() => {
this.removeFontFamily();
this.$els.glitch.addClass(this.getRandomFontFamily());
let text = this.getRandomWord();
this.$els.glitch.attr('data-text', text);
this.$els.glitch.text(text);
}, delay);
}
getRandomWord() {
return this.words[Math.floor(Math.random() * this.words.length)];
}
getRandomFontFamily() {
return this.fontFamily[Math.floor(Math.random() * this.fontFamily.length)];
}
removeFontFamily() {
for (let family of this.fontFamily) {
this.$els.glitch.removeClass(family);
}
}}
let app = new App();
app.glitch(1500);
</script>
</body>
</html>
3. Text glitch transition effect
Made by Alessandro Valeri. Source
<!DOCTYPE html>
<html lang="en" >
<head>
<title></title>
<style>
@font-face {
font-family: 'Roboto';
font-style: normal;
font-weight: 400;
src: url(https://fonts.gstatic.com/s/roboto/v30/KFOmCnqEu92Fr1Mu4mxP.ttf) format('truetype');
}
html,
body {
width: 100%;
height: 100%;
margin: 0;
padding: 0;
}
body {
display: flex;
align-items: center;
justify-content: center;
background-color: #000;
font-family: 'Roboto', sans-serif;
}
#list {
text-align: center;
display: flex;
flex-direction: column;
align-items: center;
position: relative;
}
.item {
font-size: 50px;
padding: 15px;
display: inline-block;
margin: 20px;
display: none;
}
.red {
color: red;
}
.green {
color: green;
}
.blue {
color: blue;
}
</style>
</head>
<body>
<div id="list">
<div class="item red">Lorem ipsum dolor sit ametz</div>
<div class="item red"> ea impetus similique neglegentur</div>
<div class="item red"> Et harum quidem rerum facilis est et expedita distinctio</div>
<div class="item red"> officiis debitis aut rerum necessitatibus saepe</div>
<div class="item"><img width="210" height="213" title="" alt="" src="" />
</div>
<div class="item blue">contentiones. Nam</div>
</div>
<script src="https://cpwebassets.codepen.io/assets/common/stopExecutionOnTimeout-1b93190375e9ccc259df3a57c1abc0e64599724ae30d7ea4c6877eb615f89387.js"></script>
<script src='https://cdnjs.cloudflare.com/ajax/libs/jquery/2.2.2/jquery.min.js'></script>
<script src='https://github.com/niklasvh/html2canvas/releases/download/0.4.1/html2canvas.js'></script>
<script>
(function () {
var nodes, current;
function Animation(element) {
this.element = element;
this.stepMul = 10;
this.stepTo = 4;
this.element.style.visibility = "visible";
this.canvas = document.createElement("canvas");
this.canvas.style.visibility = "hidden";
this.canvas.style.position = "absolute";
this.canvas.style.width = this.element.offsetWidth + "px";
this.canvas.style.height = this.element.offsetHeight + "px";
this.canvas.style.top = this.element.offsetTop + "px";
this.canvas.style.left = this.element.offsetLeft + "px";
this.canvas.style.zIndex = "auto";
this.context = this.canvas.getContext('2d');
this.element.parentElement.appendChild(this.canvas);
};
Animation.prototype.loadCanvas = function (callback) {
var self = this;
html2canvas(this.element, {
onrendered: function (canvas) {
self.image = new Image();
self.image.src = canvas.toDataURL();
self.canvas.style.visibility = "visible";
self.element.style.visibility = "hidden";
callback && callback();
} });
};
Animation.prototype.hide = function () {
this.step = 0;
this.showing = false;
this.loadCanvas(this.render.bind(this));
};
Animation.prototype.show = function () {
this.step = 0;
this.showing = true;
this.loadCanvas(this.render.bind(this));
};
Animation.prototype.destroy = function () {
this.canvas && this.canvas.parentElement && this.canvas.parentElement.removeChild(this.canvas);
};
Animation.prototype.render = function () {
this.context.clearRect(0, 0, this.canvas.width, this.canvas.height);
this.context.drawImage(this.image, 0, 0, this.canvas.width, this.canvas.height);
var inc = this.step / this.stepTo;
this.showing && (inc = 1 - inc);
for (var i = Math.floor(inc * this.stepMul) + 1, j = 0; j < i; j++) {if (window.CP.shouldStopExecution(0)) break;
var x = Math.random() * (this.canvas.width / 2),
y = Math.random() * this.canvas.height,
w = this.canvas.width - x,
h = 30 * Math.random() + 2;
this.context.clearRect(x, y, w, h);
this.context.clearRect(w, y, x, h);
this.context.drawImage(this.image, 0, y, w, h, x, y, w, h);
this.context.drawImage(this.image, w, y, x, h, 0, y, x, h);
}window.CP.exitedLoop(0);
if (this.step < this.stepTo) {
this.step++;
setTimeout(this.render.bind(this), Math.random() * 250);
} else {
this.destroy();
this.onComplete && this.onComplete();
}
};
function next() {
var nodeFrom = current,
nodeTo = current._next;
current = current._next;
nodeFrom.style.display = "block";
var a = new Animation(nodeFrom),
b;
a.onComplete = function () {
nodeFrom.style.display = "none";
nodeTo.style.display = "block";
b = new Animation(nodeTo);
b.onComplete = next;
b.show();
};
setTimeout(function () {a.hide();}, 3000);
}
function init() {
nodes = Array.prototype.slice.call(document.querySelectorAll(".item"));
nodes.forEach(function (value, index) {
if (index == nodes.length - 1)
nodes[index]._next = nodes[0];else
nodes[index]._next = nodes[index + 1];
});
current = nodes[0];
next();
}
document.addEventListener('DOMContentLoaded', function () {init();});
})();
</script>
</body>
</html>
4. Text glitch on Hover
Made by Lars Steen MΓΈller. Source
<!DOCTYPE html>
<html lang="en" >
<head>
<title></title>
<link rel='stylesheet' href='https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css'>
<style>
html,
body,
.container {
height: 100%;
}
body,
html {
background: #303030;
}
small {
text-transform: uppercase;
font-size: 8px;
}
.container {
/* Center slide text vertically */
display: flex;
justify-content: center;
align-items: center;
}
.container {
background: #212121;
}
a.btn {
color: white;
text-decoration: none;
text-transform: uppercase;
font-weight: 300;
letter-spacing: 2px;
}
a.btn:hover {
color: gold;
}
</style>
</head>
<body>
<div class="container">
<small>test</small><a href="#" class="btn text-code-hover-feel">Animate on hover OK?</a><small>teste</small>
</div>ddeetesd
<script src='https://cdnjs.cloudflare.com/ajax/libs/jquery/3.1.0/jquery.min.js'></script>
<script>
$(document).ready(function () {
var charPool = "!<>-_\\/[]{}β=+*^?#________"; // Code feel
var button = $('.text-code-hover-feel');
button.attr("data-text-scramble-original", button.text());
extrachars = button.text();
var intevalzor;
button.
mouseenter(function () {
intevalzor = setInterval(function () {myTimer();}, 300); // Do a random int
function myTimer() {
console.log("doo stuff");
button.text(createRandomText(extrachars));
}
}).
mouseleave(function () {
$(this).text($(this).attr("data-text-scramble-original"));
clearInterval(intevalzor);
});
function createRandomText(extrachars)
{
var text = "";
var possible = "!<>-_\\/[]{}β=+*^?#________" + extrachars + extrachars + extrachars;
for (var i = 0; i < 20; i++)
text += possible.charAt(Math.floor(Math.random() * possible.length));
return text;
}
var lengthOfText = getLenghtOfString(button.text());
var lengthOfPool = getLenghtOfString(charPool);
// console.log("TextLength: ", lengthOfText);
for (i = 0; i < lengthOfText; i++) {
console.log("hejsa");
var randomIntIndexText = selectRandomFrom(lengthOfText);
var randomIntIndexPool = selectRandomFrom(lengthOfPool);
var poolChar = getCharAtPosition(charPool, randomIntIndexPool);
}
// console.log("PoolLength ", lengthOfPool);
// console.log("Random From Text: ", selectRandomFrom(lengthOfText));
// console.log("Random From pool: ", selectRandomFrom(lengthOfPool));
getCharAtPosition(charPool, selectRandomFrom(lengthOfPool));
function getCharAtPosition(str, position) {
return str.charAt(position + 1); //daspdksaoda
}
function replaceCharInString(index, char) {
return str.substr(0, index) + 'char' + str.substr(index + 1);
}
function getLenghtOfString(element) {
return element.length;
}
function selectRandomFrom(number) {
//1 is the start number
//"number" is the number of possible results (1 + start (number) - end (1))
return Math.floor(Math.random() * number) + 1;
}
// usage str = str.replaceAt(3, "a");
function replaceLetterAt(index, character) {
return this.substr(0, index) + character + this.substr(index + character.length);
}
});
</script>
</body>
</html>
5. Text Glitch
Made by Michael Hibbs. Source
<!DOCTYPE html>
<html lang="en" >
<head>
<title></title>
<link rel='stylesheet' href='https://fonts.googleapis.com/css?family=Titillium+Web:200'>
<style>
* {
box-sizing: border-box;
}
body, html {
width: 100%;
height: 100%;
padding: 0;
margin: 0;
}
body {
color: #555;
font-family: "Titillium Web", helvetica, arial, sans-serif;
background-color: #001331;
}
#app {
display: flex;
justify-content: center;
align-items: center;
align-content: center;
width: 100%;
height: 100%;
}
.glitch-paragraph {
width: 960px;
position: relative;
font-size: 4em;
color: #fff;
}
.glitch-paragraph::before {
display: initial;
content: attr(data-text);
position: absolute;
top: -2px;
left: -2px;
text-shadow: 3px 0 #fe0000;
background-color: #001d48;
overflow: hidden;
animation: glitch 3s infinite linear alternate-reverse;
}
@keyframes glitch {
100% {
-webkit-clip-path: inset(10px 0 183px 0);
clip-path: inset(10px 0 183px 0)
}
95% {
-webkit-clip-path: inset(124px 0 58px 0);
clip-path: inset(124px 0 58px 0)
}
90% {
-webkit-clip-path: inset(114px 0 85px 0);
clip-path: inset(114px 0 85px 0)
}
85% {
-webkit-clip-path: inset(79px 0 107px 0);
clip-path: inset(79px 0 107px 0)
}
80% {
-webkit-clip-path: inset(56px 0 139px 0);
clip-path: inset(56px 0 139px 0)
}
75% {
-webkit-clip-path: inset(21px 0 165px 0);
clip-path: inset(21px 0 165px 0)
}
70% {
-webkit-clip-path: inset(122px 0 31px 0);
clip-path: inset(122px 0 31px 0)
}
65% {
-webkit-clip-path: inset(50px 0 119px 0);
clip-path: inset(50px 0 119px 0)
}
60% {
-webkit-clip-path: inset(137px 0 37px 0);
clip-path: inset(137px 0 37px 0)
}
55% {
-webkit-clip-path: inset(65px 0 122px 0);
clip-path: inset(65px 0 122px 0)
}
50% {
-webkit-clip-path: inset(138px 0 21px 0);
clip-path: inset(138px 0 21px 0)
}
45% {
-webkit-clip-path: inset(2px 0 181px 0);
clip-path: inset(2px 0 181px 0)
}
40% {
-webkit-clip-path: inset(138px 0 59px 0);
clip-path: inset(138px 0 59px 0)
}
35% {
-webkit-clip-path: inset(20px 0 135px 0);
clip-path: inset(20px 0 135px 0)
}
30% {
-webkit-clip-path: inset(42px 0 157px 0);
clip-path: inset(42px 0 157px 0)
}
25% {
-webkit-clip-path: inset(48px 0 119px 0);
clip-path: inset(48px 0 119px 0)
}
20% {
-webkit-clip-path: inset(89px 0 76px 0);
clip-path: inset(89px 0 76px 0)
}
15% {
-webkit-clip-path: inset(129px 0 35px 0);
clip-path: inset(129px 0 35px 0)
}
10% {
-webkit-clip-path: inset(15px 0 142px 0);
clip-path: inset(15px 0 142px 0)
}
5% {
-webkit-clip-path: inset(123px 0 48px 0);
clip-path: inset(123px 0 48px 0)
}
}
</style>
</head>
<body>
<div id="app">
<div data-text='Lorem ipsum dolor sit amet, adipisicing hacker' class='glitch-paragraph'>
Lorem ipsum dolor sit amet, adipisicing <span class="word-switcher" data-words='programmer,hacker'></span>
</div>
</div>
<script src='https://cdnjs.cloudflare.com/ajax/libs/lodash.js/4.17.4/lodash.min.js'></script>
<script>
var elapsedTicks = 0;
var ticksToChange = 40;
var wordSwitchers = document.querySelectorAll(".word-switcher");
function jumbleWord(word) {
var chars = "@#[]/?!";
word.innerText = _.shuffle(chars.split('')).join('');
}
function randomizeWord(word) {
var words = word.getAttribute("data-words").split(",");
word.innerText = _.sample(words);
}
function tick() {
elapsedTicks++;
if (elapsedTicks < 10) {
_.each(wordSwitchers, jumbleWord);
} else if (elapsedTicks == 10) {
_.each(wordSwitchers, randomizeWord);
} else if (elapsedTicks > ticksToChange) {
elapsedTicks = 0;
ticksToChange = _.random(40, 80);
}
}
setInterval(tick, 40);
</script>
</body>
</html>
6. Text Glitch Reveal Animation
Made by Biotree. Source
<!DOCTYPE html>
<html lang="en" >
<head>
<title></title>
<script src="https://cdn.jsdelivr.net/npm/[email protected]/dist/baffle.min.js"></script>
<style>
html,body{
padding:0;
margin:0;
border:0;
background-color:#0e1119;
}
.container{
position:absolute;
top:50%;
left:50%;
transform:translate(-50%,-50%);
}
.data{
color:white;
font-family:'Poppins',sans-serif;
font-weight:500;
text-align:centre;
letter-spacing:.5rem;
font-size:31px;
}
</style>
</head>
<body>
<div class="container">
<div class="data">IAMHARSH-WEB DEVELOPER</div>
<script>
const text = baffle(".data");
text.set({
characters: 'βββ ββββ> βββββ >β> β/β>β ββββ β<β ββββ β/ββ',
speed: 120 });
text.start();
text.reveal(4000);
</script>
</body>
</html>
7. CSS Text Glitch Effect – Baffle
Made by Rahul Chaudhary. Source
<!DOCTYPE html>
<html lang="en" >
<head>
<title></title>
<style>
* {
margin: 0;
padding: 0;
}
body{
color: #fff;
backgrounf: #fff;
font-family: Helvetica, sans-serif;
}
section{
width: 100%;
min-height: 100vh;
display: -webkit-box;
display: -moz-box;
display: -ms-flexbox;
display: -webkit-flex;
display: flex;
-ms-flex-wrap: wrap;
flex-wrap: wrap;
-webkit-flex-wrap: wrap;
-moz-flex-wrap: wrap;
justify-content: center;
align-items: center;
background: #000;
}
.text__glitch{
font-size: 30px;
letter-spacing: 1px;
text-align: center;
text-transform: Uppercase;
}
</style>
</head>
<body>
<main>
<section class="section--1">
<h3 class="text__glitch">Text Glitch Effect Using Baffle.JS</h3>
</section>
</main>
<script src='https://cdn.jsdelivr.net/npm/[email protected]/dist/baffle.min.js'></script>
<script>
//Baffle
const text = baffle(".text__glitch");
text.set({
characters: "βββ ββ/ββ ββββ/ βββ βββ/β βββ/ βββ β<ββ β/β>",
speed: 120 });
text.start();
text.reveal(4000);
</script>
</body>
</html>
8. Text glitch effect
Made by TehMerow. Source
<!DOCTYPE html>
<html lang="en" >
<head>
<title></title>
<link href="https://fonts.googleapis.com/css?family=Passion+One" rel="stylesheet">
<style>
html,
body {
margin: 0;
height: 100%;
}
.wrapper {
height: 100%;
width: 100%;
display: flex;
justify-content: center;
align-items: center;
background-color: #111;
}
#cyberpunk {
margin: 0;
padding: 0;
letter-spacing: 40px;
filter: drop-shadow(0 0 20px hsla(320, 40%, 60%, 0.8));
font-size: 64px;
position: relative;
z-index: 1;
font-family: 'Passion One', cursive;
font-style: italic;
}
.text:nth-child(1) {
color: hsl(320, 90%, 90%);
-webkit-clip-path: inset(40% 0% 40% 0%);
clip-path: inset(40% 0% 40% 0%);
z-index: 5;
}
.text:nth-child(2) {
position: absolute;
top: 0;
left: 0;
z-index: 10;
color: hsl(260, 90%, 80%);
-webkit-clip-path: inset(0% 0% 60% 0%);
clip-path: inset(0% 0% 60% 0%);
-webkit-animation: random1 1000ms steps(1) alternate infinite;
animation: random1 1000ms steps(1) alternate infinite;
}
.text:nth-child(3) {
position: absolute;
top: 0;
left: 0;
z-index: 10;
color: hsl(260, 90%, 50%);
-webkit-clip-path: inset(60% 0% 0% 0%);
clip-path: inset(60% 0% 0% 0%);
-webkit-animation: random2 1000ms steps(1) alternate infinite;
animation: random2 1000ms steps(1) alternate infinite;
}
.thing-1 {
position: absolute;
left: 0;
top: 20%;
height: 50%;
width: 100%;
background-color: hsl(225, 100%, 40%);
z-index: -1;
-webkit-animation: random-clip-1 20s steps(1) infinite;
animation: random-clip-1 20s steps(1) infinite;
}
#scanline {
position: absolute;
height: 100%;
width: 100%;
top: 0;
left: 0;
z-index: 100;
background-image: linear-gradient(to bottom, rgba(0, 0, 0, 0.5) 0%, rgba(0, 0, 0, 0.5) 50%, rgba(0, 0, 0, 0) 50%, rgba(0, 0, 0, 0) 100%);
background-size: 100% 2px;
}
</style>
</head>
<body>
<div class="wrapper">
<div id="cyberpunk">
<h1 class="text">huh?</h1>
<h1 class="text">huh?</h1>
<h1 class="text">huh?</h1>
<div class="thing-1"></div>
</div>
<div id="scanline"></div>
</div>
<script src="https://cpwebassets.codepen.io/assets/common/stopExecutionOnTimeout-1b93190375e9ccc259df3a57c1abc0e64599724ae30d7ea4c6877eb615f89387.js"></script>
<script>
Math.Ran = function (max) {
let rn = Math.round(Math.random() * max);
rn *= Math.random() > 0.5 ? -1 : 1;
return rn;
};
function generateRandomKeyFrames(dis, len, name) {
let keyframes = ``;
for (var i = 0; i < len; i++) {if (window.CP.shouldStopExecution(0)) break;
keyframes += `${i / len * 100}%{transform: translateX(${Math.Ran(dis)}px)}`;
}window.CP.exitedLoop(0);
let style = document.createElement('style');
style.innerHTML = `@keyframes ${name} { ${keyframes} }`;
document.body.appendChild(style);
}
function generateRandomClipFrames(len, name) {
let keyframes = ``;
let size = 100;
for (var i = 0; i < len; i++) {if (window.CP.shouldStopExecution(1)) break;
keyframes +=
`${i / len * 100}%{
clip-path: inset(${Math.Ran(size)}% ${Math.Ran(size)}% ${Math.Ran(size)}% ${Math.Ran(size)}%)
}`;
}window.CP.exitedLoop(1);
let style = document.createElement('style');
style.innerHTML = `@keyframes ${name} {
${keyframes}
}`;
document.body.appendChild(style);
}
generateRandomKeyFrames(15, 16, "random1");
generateRandomKeyFrames(10, 10, "random2");
generateRandomClipFrames(200, "random-clip-1");
</script>
</body>
</html>