Свойство animation-fill-mode устанавливает в каком положении останавливаться анимации после окончания. По умолчанию анимация возвращается в первоначальное значение и это может выглядеть не очень красиво.

Данное свойство входит в свойство-сокращение animation.

См. все свойства для CSS анимации animation-name, animation-duration, animation-delay, animation-timing-function, animation-iteration-count, animation-direction, animation-fill-mode, animation-play-state, keyframes.

См. также transition - плавные переходы (анимация по наведению на элемент).

Синтаксис

селектор {
	animation-fill-mode: backwards | forwards | both | none;
}

Для добавления нескольких анимаций следует задавать значения через запятую:

селектор {
	animation-duration: backwards, forwards, forwards;
}

Значения

Значение Описание
none Если установлена задержка анимации - то в течении времени задержки элемент будет оставаться на месте, а потом скачком перейдет к 0% кадру. После окончания анимации элемент не останется в том состоянии, где остановился, а перепрыгнет в начальное состояние.
backwards Заставляет элемент двигаться после загрузки страницы к 0% кадру, даже если установлена задержка animation-delay, и оставаться там, пока не начнется анимация. После окончания анимации элемент не останется в том состоянии, где остановился, а перепрыгнет в начальное состояние.
forwards Указывает браузеру, что после окончания анимации элемент останется в том состоянии, где остановился.
both Включает в себя backwards и forwards - после загрузки страницы элемент установится к 0% кадру, а после окончания анимации элемент останется там, где остановился.

Значение по умолчанию: none.

Примеры

Пример . Значение none

В данном примере margin-left установлен в значение 300px для элемента, а для первого кадра анимации - в 0px. Так как нет задержки animation-delay, то элемент после загрузки страницы станет в 0px, а не в 300px. Кроме того,анимация после окончания будет перепрыгивать в начальное значение:

@keyframes move {
	from {
		margin-left: 0px;
	}
	to {
		margin-left: 400px;
	}
}

#elem {
	margin-left: 300px;
	animation-fill-mode: none;
	animation-delay: 0s;
	animation-duration: 3s;
	animation-name: move;
	animation-iteration-count: infinite;
	animation-timing-function: linear;
	border: 1px solid black;
	width: 50px;
	height: 50px;
}

Результат выполнения кода:

Наведи на меня, что анимация началась.

Пример . Значение none

В данном примере margin-left установлен в значение 300px для элемента, а для первого кадра анимации - в 0px. Также для элемента установлена задержка animation-delay в 3 секунды, поэтому элемент после загрузки страницы станет в 300px, а не в 0px, и будет стоять там 3 секунды после начала анимации а потом скачком перейдет к 0px - и анимация начнется оттуда. Кроме того,анимация после окончания будет перепрыгивать в начальное значение:

@keyframes move {
	from {
		margin-left: 0px;
	}
	to {
		margin-left: 400px;
	}
}

#elem {
	margin-left: 300px;
	animation-fill-mode: none;
	animation-delay: 0s;
	animation-duration: 3s;
	animation-name: move;
	animation-iteration-count: infinite;
	animation-timing-function: linear;
	border: 1px solid black;
	width: 50px;
	height: 50px;
}

Результат выполнения кода:

Наведи на меня, что анимация началась.

Пример . Значение backwards

В данном примере margin-left установлен в значение 300px для элемента, а для первого кадра анимации - в 0px. Также для элемента установлен animation-fill-mode в значении backwards, поэтому элемент после загрузки страницы станет в 0px, а не в 300px, как это было для animation-fill-mode в значении none. Кроме того,анимация после окончания будет перепрыгивать в начальное значение:

@keyframes move {
	from {
		margin-left: 0px;
	}
	to {
		margin-left: 400px;
	}
}

#elem {
	margin-left: 300px;
	animation-fill-mode: backwards;
	animation-delay: 0s;
	animation-duration: 3s;
	animation-name: move;
	animation-iteration-count: infinite;
	animation-timing-function: linear;
	border: 1px solid black;
	width: 50px;
	height: 50px;
}

Результат выполнения кода:

Наведи на меня, что анимация началась.

Пример . Значение none и количество повторений равно 1

В данном примере margin-left установлен в значение 300px для элемента, а для первого кадра анимации - в 0px. Также для элемента установлена задержка animation-delay в 3 секунды, поэтому элемент после загрузки страницы станет в 300px, а не в 0px, и будет стоять там 3 секунды после начала анимации а потом скачком перейдет к 0px - и анимация начнется оттуда. Так как animation-fill-mode установлен в значении none, то после проигрывания анимации элемент вернется в начальное значение:

@keyframes move {
	from {
		margin-left: 0px;
	}
	to {
		margin-left: 400px;
	}
}

#elem {
	margin-left: 300px;
	animation-fill-mode: none;
	animation-delay: 3s;
	animation-duration: 3s;
	animation-name: move;
	animation-iteration-count: 1;
	animation-timing-function: linear;
	border: 1px solid black;
	width: 50px;
	height: 50px;
}

Результат выполнения кода:

Наведи на меня, что анимация началась.

Пример . Значение forwards и количество повторений равно 1

В данном примере animation-fill-mode установлен в значении forwards, а число повторений анимации - в 1. После проигрывания анимации элемент останется в том положении, где закончилась анимация, а не прыгнет в исходную точку.

Кроме того, margin-left установлен в значение 300px для элемента, а для первого кадра анимации - в 0px. Также для элемента установлена задержка animation-delay в 3 секунды, поэтому элемент после загрузки страницы станет в 300px, а не в 0px, и будет стоять там 3 секунды после начала анимации а потом скачком перейдет к 0px - и анимация начнется оттуда.

@keyframes move {
	from {
		margin-left: 0px;
	}
	to {
		margin-left: 400px;
	}
}

#elem {
	margin-left: 300px;
	animation-fill-mode: forwards;
	animation-delay: 3s;
	animation-duration: 3s;
	animation-name: move;
	animation-iteration-count: 1;
	animation-timing-function: linear;
	border: 1px solid black;
	width: 50px;
	height: 50px;
}

Результат выполнения кода:

Наведи на меня, что анимация началась.

Пример . Значение both и количество повторений равно 1

В данном примере animation-fill-mode установлен в значении both, а число повторений анимации - в 1. После загрузки страницы элемент будет стоять в первом кадре анимации (в 0px, а не в 300px), а после проигрывания анимации элемент останется в том положении, где закончилась анимация, а не прыгнет в исходную точку.

@keyframes move {
	from {
		margin-left: 0px;
	}
	to {
		margin-left: 400px;
	}
}

#elem {
	margin-left: 300px;
	animation-fill-mode: both;
	animation-delay: 3s;
	animation-duration: 3s;
	animation-name: move;
	animation-iteration-count: 1;
	animation-timing-function: linear;
	border: 1px solid black;
	width: 50px;
	height: 50px;
}

Результат выполнения кода:

Наведи на меня, что анимация началась.