좋아요
지금쯤 여러분은
'setInterval'을 쓸 지
'requestAnimationFrame'
을 쓸 지 고민이 될 거에요
여러분이
효과를 주고 싶을 때요
하지만 전
더 나아가서
다른 선택지를
제시할게요
크롬, 파이어폭스와
익스플로러 10 이상에서는
CSS로 효과를 주는
다른 방법이 있어요
자바스크립트를
사용하지 않고 말이죠
방금 쓴 코드를
주석 처리하고
ohnoes 효과를
적용해 볼게요
여기 전체를
주석 처리할게요
태그를
추가하는 걸로 시작해보죠
그리고 CSS 규칙같은 걸
추가할거에요
하지만 사실 이건
효과를 정의하는 것이죠
여기에
'@keyframes'을 쓰고
효과의 이름을
쓰세요
'getbigger'
그리고
중괄호를 닫아요
이 간단한 효과를
주기 위해서는
한 상태에서
다른 상태로 전환시킬 때요
이걸 시작(from)과
종료(to)상태라고 할게요
시작상태(from)
안에는
시작 CSS 속성에 대해
적어주면 돼요
처음에 50픽셀로
정했던 것 기억나죠?
종료상태(to)
안에는
종료 속성에 대해
적어주면 돼요
이건 아마 300픽셀 정도
였을거에요
기억나시죠?
이제 효과를
정의했으니까
브라우저에게
말해줘야해요
어떤 요소에
이 효과를 적용할 지 말이죠
그래서 ohnoes에게
일반적인 CSS규칙을 줄 거에요
이 안에서는
효과 이름을 정해주고
그러니까
'getbigger'죠
효과 지속시간을
정해줘요
3초 겠네요
여러분이 사용하는
브라우저에 따라서
이렇게 생각하고
있을지도 몰라요
우와 멋져요
작동하네요!
하지만
다른 브라우저에서는
사파리나
크롬에서는 말이죠
작동하지
않을 수도 있어요
그건 '브라우저 접두어'
(vendor prefix) 때문이에요
종종
브라우저는
멋진 새 기능을
도입하기로 하는데
하지만 그 기능에
접두어를 붙여서
이건 나중에 바뀔 수도 있다고
표시해 주는 거에요
이건 그냥
그 브라우저의
그 기능에 대한
접근일 뿐이에요
크롬에서
작동하게 하려면
만약 아직 기능이
준비가 되지 않았다면
우리가 방금 했던 걸
복사해서
앞에 'webkit'을
추가해줘야 해요
그러니까
이 부분을 똑같이 쓰고
'-webkit-'을
여기다 쓰세요
그리고 여기도 또 쓰고
'-webkit-'을 붙이세요
우와
멋져요!
이제 모든 브라우저에서
커지게 될 거에요
여러분이 이 영상을
볼 때 쯤이면
브라우저 접두어를
안 써도 됐으면 좋겠네요
하지만 이런 게 있다는 걸
알고있으면 좋아요
다음에 이걸 언젠가
써야할 때가 올 지도 모르니까요
CSS로 효과를 주는 방법이
또 한가지 더 있어요
이건 전환 속성을
사용하는 거에요
브라우저가 부드럽게
전환을 할 수있게 해줘요
한 속성에서
다음 속성으로요
예를 들어
글자 크기를
남은 시간에 따라
커지게 하고 싶다고 해요
마우스 포인터를
위에 올릴 때 말이죠
이걸 자바스크립트로
할 수 있어요
마우스 오버에 대한
이벤트를 주는 걸로요
그리고 requestAnimationFrame
을 사용해서
매번 글자 크기 속성을
증가시켜주는 거에요
하지만 이걸
CSS만으로도 할 수 있어요
생각해봐요
일반적으로
글자 크기를 어떻게 키우죠?
CSS에서 마우스를
올렸을 때 말이죠
이건 호버(hover)를
사용하면 할 수 있어요
'#countdown: hover'
라고 쓰고
'font-size: 150px;'
라고 해요
좋아요
이제 우리는 브라우저에게
글자 크기 속성을
전환시키고
전환이 얼마 동안
일어나야 하는지 말해줘야해요
그리고 어떤
시간 함수를 쓸 지도요
'transition: font-size 1s linear'
라고 쓰고
이제 이 프로그램을
멈추고
마우스를 올리고
어떻게 되나 보세요
크롬, 파이어폭스나
익스플로러 10 이상을 쓴다면
이건 천천히
커지게 될 거에요
이 방식을 쓰면
브라우저 접두어는 필요없어요
여러분이 할 수 있는
수많은 것들이 있어요
CSS효과와 전환을
사용해서 말이죠
그리고 브라우저는 빠르게
효과를 잘 만들어 줘요
그러니까 두 가지 모두
많이 찾아보길 바래요