7+ JavaScript Text Glitch Effect Examples

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>