웹 프론트엔드 CSS 튜토리얼 프런트엔드 애니메이션을 구현하는 7가지 방법 요약(코드 포함)

프런트엔드 애니메이션을 구현하는 7가지 방법 요약(코드 포함)

Aug 20, 2018 am 11:10 AM
프런트엔드 애니메이션

이 글은 프론트엔드 애니메이션을 구현하는 데 사용할 수 있는 7가지 방법(코드 포함)을 요약한 것입니다. 도움이 필요한 친구들이 참고할 수 있기를 바랍니다.

1. JavaScript는

기본 아이디어는 setInterval 또는 setTimeout 메소드의 콜백 함수를 통해 요소의 CSS 스타일을 지속적으로 호출하고 변경하여 요소 스타일 변경 효과를 얻는 것입니다. .

<div id="rect"></div>
 
    <script>
 
        let elem = document.getElementById(&#39;rect&#39;);
 
        let left = 0;
 
        let timer = setInterval(function(){
 
            if(left<window.innerWidth-200){
 
                elem.style.marginLeft = left+&#39;px&#39;;
 
                left ++;
 
            }else {
 
                clearInterval(timer);
 
            }
 
        },16);
 
</script>
로그인 후 복사

단점: Javascript로 애니메이션을 구현하면 일반적으로 페이지가 자주 다시 정렬되고 다시 그려지므로 성능이 소모됩니다. 일반적으로 데스크톱 브라우저에서 사용해야 합니다. 모바일 단말기에서 사용할 때 명백한 지연이 발생합니다.

2, SVG(확장 가능한 벡터 그래픽);

4, CSS3 애니메이션,

6, requestAnimationFrame;

requestAnimationFrame은 또 다른 웹 API이며 그 원리는 setTimeout 및 setInterval과 유사합니다. 이는 javascript의 연속 루프 메소드 호출을 통해 애니메이션 작업을 트리거합니다. 하지만 requestAnimationFrame은 브라우저에서 애니메이션용으로 특별히 최적화한 API로 성능이 다른 두 가지보다 뛰어납니다.

    <div id="rect"></div>
 
 <script type="text/javascript">
 
window.requestAnimationFrame = window.requestAnimationFrame||window.mozRequestAnimationFrame||window.webkitRequestAnimationFrame||window.msRequestAnimationFrame;
 
    let elem = document.getElementById("rect");
 
    let left = 0;
 
    //自动执行持续性回调
 
    requestAnimationFrame(step);
 
    //持续该改变元素位置
 
    function step() {
 
        if(left<window.innerWidth-200){
 
            left+=1;
 
            elem.style.marginLeft = left+"px";
 
            requestAnimationFrame(step);
 
        }
 
    }
 
</script>
로그인 후 복사
7, jq animation

1) 표시 및 숨기기:

.show(ms) .hide(ms) .toggle(ms) 매개변수가 없으면 기본값은 애니메이션 없이 즉시 표시하고 숨기는 것입니다. 표시 속성이 밀리초 매개변수로 구현됩니다. 애니메이션 효과가 있습니다.

toggle은 숨겨진 요소를 표시하고 표시된 요소를 숨깁니다.2) 위아래로 슬라이드: .slideUp(ms) .slideDown(ms) .slideToggle(ms)

3) 페이드 인 및 페이드 아웃: .fadeIn(ms) .fadeOut (ms) .fadeToggle(ms)

2. 범용 애니메이션:

$(...).animate(params,speed,callback)

params: 스타일 속성과 값을 포함하는 매핑 ​​

speed: 속도 매개변수 [선택]

콜백: 애니메이션이 완료되면 실행되는 함수[선택], 콜백 함수에서 이는 애니메이션을 재생 중인 현재 DOM 요소를 나타냅니다

8. 요약

데스크탑 브라우저는 자바스크립트 직접 사용을 권장합니다. 애니메이션 또는 SVG 방법 구현

모바일 단말기는 CSS3transition, CSS3animation, Canvas 또는 requestAnimationFrame 방법

관련 권장 사항:

프런트 엔드 개발에서 SVG 애니메이션

모바일 웹 프론트 엔드 개발 CSS 애니메이션 경험 공유_ html/css_WEB-ITnose


모바일 애니메이션 기능 encapsulation_html/css_WEB-ITnose

위 내용은 프런트엔드 애니메이션을 구현하는 7가지 방법 요약(코드 포함)의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

WordPress 블록 및 요소에 상자 그림자를 추가합니다 WordPress 블록 및 요소에 상자 그림자를 추가합니다 Mar 09, 2025 pm 12:53 PM

CSS Box-Shadow 및 개요 속성은 주제를 얻었습니다. 실제 테마에서 어떻게 작동하는지에 대한 몇 가지 예와 이러한 스타일을 WordPress 블록 및 요소에 적용 해야하는 옵션을 보자.

GraphQL 캐싱 작업 GraphQL 캐싱 작업 Mar 19, 2025 am 09:36 AM

최근에 GraphQL 작업을 시작했거나 장단점을 검토 한 경우 "GraphQL이 캐싱을 지원하지 않음"또는

첫 번째 맞춤형 전환을 만듭니다 첫 번째 맞춤형 전환을 만듭니다 Mar 15, 2025 am 11:08 AM

Svelte Transition API는 맞춤형 전환을 포함하여 문서를 입력하거나 떠날 때 구성 요소를 애니메이션하는 방법을 제공합니다.

고급스럽고 멋진 커스텀 CSS 스크롤 바 : 쇼케이스 고급스럽고 멋진 커스텀 CSS 스크롤 바 : 쇼케이스 Mar 10, 2025 am 11:37 AM

이 기사에서 우리는 스크롤 바의 세계로 뛰어들 것입니다. 너무 화려하게 들리지는 않지만 잘 설계된 페이지가 손을 잡고 있습니다.

쇼, 말하지 마십시오 쇼, 말하지 마십시오 Mar 16, 2025 am 11:49 AM

웹 사이트의 컨텐츠 프레젠테이션을 설계하는 데 얼마나 많은 시간을 소비합니까? 새 블로그 게시물을 작성하거나 새 페이지를 만들 때

Redwood.js 및 동물 군을 사용하여 이더 리움 앱 구축 Redwood.js 및 동물 군을 사용하여 이더 리움 앱 구축 Mar 28, 2025 am 09:18 AM

최근 Bitcoin의 가격이 20k 달러가 넘는 USD가 최근에 등반되면서 최근 30k를 끊었으므로 Ethereum을 만드는 데 깊이 다이빙을 할 가치가 있다고 생각했습니다.

NPM 명령은 무엇입니까? NPM 명령은 무엇입니까? Mar 15, 2025 am 11:36 AM

NPM 명령은 서버 시작 또는 컴파일 코드와 같은 것들에 대한 일회성 또는 지속적으로 실행되는 프로세스로 다양한 작업을 실행합니다.

특이성에 대해 이야기하기 위해 (X, X, X, X)를 사용해 보겠습니다. 특이성에 대해 이야기하기 위해 (X, X, X, X)를 사용해 보겠습니다. Mar 24, 2025 am 10:37 AM

나는 다른 날에 Eric Meyer와 대화를 나누고 있었고 나는 내 형성 시절부터 Eric Meyer 이야기를 기억했습니다. CSS 특이성에 대한 블로그 게시물을 썼습니다

See all articles