CSS層疊樣式表(英文全稱:Cascading Style Sheets)是一種用來表現HTML(標準通用標記語言的一個應用)或XML(標準通用標記語言的一個子集)等文件樣式的計算機語言。CSS不僅可以靜態(tài)地修飾網頁,還可以配合各種腳本語言動態(tài)地對網頁各元素進行格式化。CSS 能夠對網頁中元素位置的排版進行像素級精確控制,支持幾乎所有的字體字號樣式,擁有對網頁對象和模型樣式編輯的能力。
站在用戶的角度思考問題,與客戶深入溝通,找到紅崗網站設計與紅崗網站推廣的解決方案,憑借多年的經驗,讓設計與互聯網技術結合,創(chuàng)造個性化、用戶體驗好的作品,建站類型包括:網站設計、網站制作、企業(yè)官網、英文網站、手機端網站、網站推廣、空間域名、網絡空間、企業(yè)郵箱。業(yè)務覆蓋紅崗地區(qū)。所有動畫的基本原理都是:在短時間內連續(xù)依次展示對應的圖片,這樣在視覺上看起來就是'動'的了。本文主要來說一說第4點和第5點。
當我們要實現的動畫效果比較復雜,而且開發(fā)排期比較緊的情況下,用一張gif動圖來實現動畫是成本最低,效果也不錯的一種方案。比如下面這種動畫效果:
可是如果我們想讓動效在某個時候暫停,隔一段時間后,再從斷點開始繼續(xù)播放動效,用gif圖就實現不了了。gif圖的動效是沒有辦法暫停的。這個時候,可以考慮采用圖片幀動畫。
圖片幀動畫可以看做是:把gif圖的原理在前端用代碼實現了一遍。
上面?zhèn)€那個動效,(假設)可以分成100幀,即100張圖片,然后用代碼控制100張圖片依次顯示。并且,可以隨時在中途暫停。為了節(jié)省http請求,把100張圖片合成一張雪碧圖,然后用background-position去控制顯示哪一張圖。推薦一個很不錯的圖片生成工具:GKA
我把100張圖片生成了一個豎直的雪碧圖。
在代碼里,只需要更新DOM元素的background-position即可實現動畫。
首先第一個點需要注意:background-position設置的是背景圖片相對于DOM元素的起始位置。
假設DOM元素和圖片寬高都是 100 * 200
#wrapper {
width: 100px;
height: 200px;
background-image: url('雪碧圖.png');
background-size: 100% 10000%; // 有100張圖, 100*100
background-repeat: no-repeat;
}
--- js
var domEl = document.querySelector('#wrapper');
var n; // n:顯示雪碧圖中第幾張圖片,n >=0 && n<100
domEl.style.backgroundPosition = `0px ${-n*200}px`; // 注意這里是負值
我們只需要用js控制n的值就行,就可以很容易實現隨時執(zhí)行、暫停動效。
上面的例子中,dom元素寬高是固定的,如果不固定、想要自適應的話,需要根據圖片寬高比,通過padding-top來設置dom元素的寬高比。這個時候,在background-position中,也無法使用具體的數值了,需要使用百分比。這里有一個需要注意的地方:
background-position百分比取值時,很自然的以為是直接用背景圖片寬高乘以百分比即可得到最終偏移量,但其實不是的。計算公式如下:
x偏移量 = (元素寬度—背景圖片的寬度)*x百分比
y偏移量 = (元素高度—背景圖片的高度)*y百分比
換算一下:
x百分比 = x偏移量 / (元素寬度 - 背景圖片寬度)
y百分比 = y偏移量 / (元素高度 - 背景圖片高度)
具體到上面的例子中,就是:
// 假設每一張小圖片寬度為w, 高度為h, 當前需要展示第n張圖片,一共有100張圖,則
var xPercent = 0;
var yPercent = -hn / (h - 100h) * 100 = n / 99 * 100;
domEl.style.backgroundPosition = `${xPercent}% ${yPercent}%`;
最終,我們就能實現圖片幀動畫了。當然,如果不需要完全控制動畫效果,可以不借助js,直接用css即可?;蛘咧苯佑胓if動圖就好。
曲線運動,使用svg,canvas是很不錯的選擇。但是在對曲線的路徑不那么嚴格要求的時候,使用svg和canvas或許略微麻煩了??梢灾苯佑胏ss來實現一個『看起來是曲線』的運動。
以類似拋物線的一個運動為例,大概是一個這樣的效果:
位移曲線上某點的切線就是速度,而速度可以分解成x軸的速度和y軸的速度。也就是說,上面的運動可以分解成水平方向x軸的運動和豎直方向y軸的運動。從感官上,不難看出,x軸的運動大概是勻速的,而y軸的運動是越來越快的。
另外,由于運動分解成了兩個方向的運動,需要兩個DOM,分別寫動畫,才能實現最終的效果。
--- html
--- css
.x-container {
width: 50px;
height: 50px;
animation: xMove 2s linear;
}
.y-container {
width: 50px;
height: 50px;
border-radius: 50%;
background-color: #000;
animation: yMove 2s cubic-bezier(.98,.03,.91,.77);
}
@keyframes xMove {
0% {
}
100% {
transform: translateX(400px);
}
}
@keyframes yMove {
0% {
}
100% {
transform: translateY(400px);
}
}
兩個方向的運動合起來,就是上面的效果了。
想要實現一個不那么嚴格的曲線運動,直接使用css animation,也是一個不錯的選擇。
另外有需要云服務器可以了解下創(chuàng)新互聯cdcxhl.cn,海內外云服務器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務器、裸金屬服務器、高防服務器、香港服務器、美國服務器、虛擬主機、免備案服務器”等云主機租用服務以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應用場景需求。