我們一般做水平三列佈局都是用的float方法,將每一塊浮動顯示在同一行。這種方法會導致元素沒有原來的高度屬性,要用清除浮動來解決空間佔據問題。對於那些特殊佈局非常不方便,例如,垂直居中就不容易實現。
2009年,W3C 提出了一個新的方案----Flex 佈局,可以簡單、完整、響應式地實現各種頁面佈局。目前,它已經得到了幾乎所有瀏覽器的支持,這意味著,現在就能很安全地使用這項功能。基本語法查看部落格:Flex 佈局教學:語法篇
另外還要對css中的偽元素有一定的了解:before、after
最後想要表情動起來,最主要的就是animation屬性的使用了。
我們先對整體座椅個佈局,使各個表情能直觀的展示在各個位置上,因為每個表情幾乎佔據的是一個正方形的空間,所以我們將每個青蛙表情水平展示在頁面上,這裡就用到了flex佈局方式。
<p class="container"> <!--所有表情的存放容器,flex布局,所有子项目水平显示,自动换行,水平居中显示,竖直方向从顶部开始--> <p class="emoji-container"> <!--存放青蛙表情的大容器,控制大小间距之类的属性--> <p class="icon"> <!--存放每一个青蛙表情的容器,控制每一个表情自己的位置和特征--> <p class="frog" id="frog-n"></p></p></p></p> body {background-color: #F1FFE6;} .container {width: 950px;margin: 70px auto 0px auto;text-align: center;} .container .emoji-container { /*flex弹性布局,多用于左右并排布局,跟float的作用类似,不用清除浮动*/ display: -webkit-box; display: -ms-flexbox; display: flex; /*justify-content属性定义了项目在主轴上的对齐方式。center就是在x轴上居中显示*/ -ms-grid-column-align: center; justify-items: center; /*align-items属性定义项目在交叉轴上如何对齐。flex-start就是从y轴的最上端开始排列*/ -webkit-box-align: start; -ms-flex-align: start; align-items: flex-start; /*flex-wrap属性定义,如果一条轴线排不下,如何换行。wrap:换行,第一行在上方。*/ -ms-flex-wrap: wrap; flex-wrap: wrap; } .container .emoji-container .icon { margin-right: 40px; margin-bottom: 40px; } .container .emoji-container .icon:nth-child(6n) { margin-right: 0px; } .icon {width: 125px;height: 120px;position: relative;} .icon .frog {position: absolute; top: 0;left: 0;width: 100%;height: 100%;}
觀察一個每一個蛙蛙表情,雖然每一個表情形態各異,但是它們的身體、嘴巴、眼睛、小紅暈的位置和大小幾乎都是一致,這些一致的樣式我們可以寫成公用樣式,每個蛙蛙的特徵再根據每個人蛙蛙的id寫單一的樣式進行重繪或覆蓋。
<p class="frog" id="frog-1"> <!-- 蛙蛙的身体部分 --> <p class="body"> <!-- 蛙蛙的嘴巴 --> <p class="mouth"></p> </p> <!-- 蛙蛙的眼睛 --> <p class="eyes"> <!-- 蛙蛙的左右眼睛 --> <p class="eye eye-left"> <!-- 蛙蛙的内眼圈儿 --> <p class="eye-inner"> <!-- 蛙蛙的眼珠 --> <p class="pupil"> <!-- 蛙蛙眼圈里的光晕 --> <p class="light"></p> </p> </p> </p> <p class="eye eye-right"> <p class="eye-inner"> <p class="pupil"> <p class="light"></p> </p> </p> </p> </p> </p> /*蛙蛙身体部分样式*/ .icon .frog .body { width: 110px; height: 86px; background-color: #A3D768; border-radius: 50%; position: absolute; top: 25px;left: 0; right: 0; margin: auto;box-shadow: 4px 4px 0px 0px rgba(163, 215, 104, 0.3); } /*蛙蛙嘴巴部分样式,因为每个蛙蛙的嘴巴不一样,所以公共样式就只定义了位置*/ .icon .frog .body .mouth { margin: auto; } .icon .frog .eyes { width: 86px; height: 35px; position: absolute; top: 8px; left: 0;right: 0; margin: auto; } /*蛙蛙眼睛部分样式*/ .icon .frog .eyes .eye {width: 35px;height: 35px;} .icon .frog .eyes .eye:before {content: "";display: block;width: 100%;height: 100%; background-color: #A3D768;border-radius: 50%; } /*蛙蛙眼圈部分样式*/ .icon .frog .eyes .eye .eye-inner {background-color: #fff;width: 80%;height: 80%; position: absolute;top: 10%;left: 10%;border-radius: 50%; } /*蛙蛙眼珠部分样式*/ .icon .frog .eyes .eye .eye-inner .pupil {background-color: #3F6A34; width: 60%;height: 60%;position: absolute;top: 20%;left: 20%;border-radius: 50%; } /*蛙蛙眼珠里的亮光部分样式*/ .icon .frog .eyes .eye .eye-inner .pupil .light {background-color: #fff; width: 50%;height: 50%;position: absolute;top: 10%;left: 10%;border-radius: 50%; } /*蛙蛙左右两边眼睛的位置*/ .icon .frog .eyes .eye-left {position: absolute;top: 0px;left: 0;}.icon .frog .eyes .eye-right {position: absolute;top: 0px;right: 0;}
第一隻小青蛙是在基本樣式的基礎上有一個嘴角上揚的動態效果,所以要完成第一隻蛙蛙的繪製,只要在公用樣式的基礎上加上嘴巴的動效就可以了,dom結構也是一樣的。
.frog#frog-1 .body .mouth { width: 18px;height: 22px; border-bottom: 3px solid #3F6A34; position: absolute;top: 6px;left: 0;right: 0; -webkit-animation: smile 3.8s linear 0s infinite; animation: smile 3.8s linear 0s infinite; } @-webkit-keyframes smile { 0% { border-radius: 0%; } 20% { border-radius: 50%; } 70% { border-radius: 50%; } } @keyframes smile { 0% { border-radius: 0%; } 20% { border-radius: 50%; } 70% { border-radius: 50%; } }
<p class="frog" id="frog-2"> <p class="body"> <!--存放蛙蛙的脸颊红晕--> <p class="blush"></p> <!--加上大嘴巴的class big-month--> <p class="mouth big-mouth"></p> </p> <p class="eyes"> <p class="eye eye-left"> <p class="eye-inner"> <p class="pupil"> <p class="light"></p> </p> </p> </p> <p class="eye eye-right"> <p class="eye-inner"> <p class="pupil"> <p class="light"></p> </p> </p> </p> </p> </p>/*第二只青蛙脸颊两边的红晕样式* /.icon .frog .body .blush {width: 75px;height: 9px;position: absolute; top: 20px;left: 0;right: 0;margin: auto; } .icon .frog .body .blush:before, .icon .frog .body .blush:after { content: ""; display: block;width: 12px;height: 100%;background-color: #F7D2C9;border-radius: 50%; } .icon .frog .body .blush:before {position: absolute;top: 0;left: 0;} .icon .frog .body .blush:after {position: absolute;top: 0;right: 0;} /*第二只青蛙的嘴巴样式,用圆角和阴影的方式制作而成*/ .icon .frog .body .big-mouth {width: 30px;height: 20px;border-radius: 0 0 50% 50%; box-shadow: 2px 2px 0px 0px rgba(63, 106, 52, 0.3); } .frog#frog-2 .mouth {background-color: #fff;position: absolute;top: 30px;left: 0;right: 0; } /*第二只青蛙的眼睛样式,将眼圈的背景设置为透明色,圆圈里面的亮光隐藏*/ .frog#frog-2 .eye-inner {top: 17%;background-color: transparent !important; -webkit-animation: hearts 0.6s linear 0s infinite alternate; animation: hearts 0.6s linear 0s infinite alternate; } @-webkit-keyframes hearts {0% { -webkit-transform: scale(0.7); transform: scale(0.7); }100% { -webkit-transform: scale(1); transform: scale(1); } } @keyframes hearts {0% { -webkit-transform: scale(0.7); transform: scale(0.7); }100% { -webkit-transform: scale(1); transform: scale(1); } } /*第二只青蛙的眼睛的爱心样式,左上角和右上角设置交圆角50%,然后左右对应的旋转45度合并成一个爱心的形状*/ .frog#frog-2 .eye-inner:before, .frog#frog-2 .eye-inner:after {content: "";display: block; height: 70%;width: 40%;background-color: #C71F1C;border-radius: 50% 50% 0 0; } .frog#frog-2 .eye-inner:before {position: absolute;top: 0;left: 5px; -webkit-transform: rotate(-45deg); transform: rotate(-45deg); } .frog#frog-2 .eye-inner:after {position: absolute;top: 0;right: 5px; -webkit-transform: rotate(45deg); transform: rotate(45deg); } .frog#frog-2 .eye-inner .pupil {display: none;}#第二隻蛙蛙動圖.gif第第三隻小青蛙
<p class="frog" id="frog-3"> <p class="body"> <p class="mouth"> <!--存放舌头样式的容器--> <p class="toungue"></p> </p> </p> <p class="eyes"> <!--左眼添加wink的样式,作为左眼眯眼样式--> <p class="eye eye-left wink"> <p class="eye-inner"> <p class="pupil"> <p class="light"></p> </p> </p> </p> <p class="eye eye-right"> <p class="eye-inner"> <p class="pupil"> <p class="light"></p> </p> </p> </p> </p> </p> /*第三只小青蛙的左眼眯眼样式*/ .icon .frog .eyes .eye.wink .eye-inner { background-color: transparent; width: 17px; height: 3px; background-color: #3F6A34; border-radius: 0; position: absolute; top: 15px; left: 0; right: 0; margin: auto; -webkit-transform: rotate(21deg); transform: rotate(21deg); } .icon .frog .eyes .eye.wink .eye-inner:before, .icon .frog .eyes .eye.wink .eye-inner:after { content: ''; display: block; width: 17px; height: 3px; background-color: #3F6A34; } .icon .frog .eyes .eye.wink .eye-inner:before { -webkit-transform: rotate(25deg); transform: rotate(25deg); position: absolute; top: -4px; left: 0; } .icon .frog .eyes .eye.wink .eye-inner:after { -webkit-transform: rotate(-25deg); transform: rotate(-25deg); position: absolute; top: 4px; left: 0; } .icon .frog .eyes .eye.wink .pupil { display: none; } /*第三只小青蛙的右眼亮光位置*/ .frog#frog-3 .eye-right .light { position: absolute; top: 10%; left: auto; right: 10%; } /*第三只小青蛙的嘴巴吐舌头样式*/ .frog#frog-3 .mouth { width: 25px; height: 25px; position: absolute; top: 5px; left: 0; right: 0; -webkit-transform: rotate(23deg); transform: rotate(23deg); } .frog#frog-3 .mouth:before { content: ""; display: block; border-bottom: 3px solid #3F6A34; width: 100%; height: 100%; border-radius: 50%; background-color: #A3D768; z-index: 3; position: absolute; top: 0px; left: 0; } .frog#frog-3 .toungue { width: 16px; height: 20px; background-color: #C71F1C; border-radius: 30px; z-index: 2; position: absolute; top: 17px; left: 4px; -webkit-transform-origin: center top; transform-origin: center top; -webkit-animation: toungue 2.0s linear 0s infinite; animation: toungue 2.0s linear 0s infinite; } @-webkit-keyframes toungue { 0% { -webkit-transform: scale(1, 1); transform: scale(1, 1); } 40% { -webkit-transform: scale(1, 1); transform: scale(1, 1); } 75% { -webkit-transform: scale(1, 0); transform: scale(1, 0); } } @keyframes toungue { 0% { -webkit-transform: scale(1, 1); transform: scale(1, 1); } 40% { -webkit-transform: scale(1, 1); transform: scale(1, 1); } 75% { -webkit-transform: scale(1, 0); transform: scale(1, 0); } } .frog#frog-3 .toungue:before { content: ""; display: block; width: 2px; height: 4px; background-color: #410a09; position: absolute; left: 0px; right: 0px; bottom: 5px; margin: auto; opacity: 0.4; }#第三隻蛙蛙動圖.gif #第四隻小青蛙第四隻小青蛙相對於公共樣式的變化是眼睛和嘴巴的變化,眼睛的眼珠裡面有兩個亮光點,嘴巴是大嘴巴並且可以一張一合,嘴巴裡面還有一個小舌頭。它的光暈處於一會有一會沒有的狀態。
<p class="frog" id="frog-4"> <p class="body"> <p class="mouth big-mouth"> <p class="toungue"></p> </p> </p> <p class="eyes"> <!--控制另一个眼珠闪光点的样式extra-light--> <p class="eye eye-left extra-light"> <p class="eye-inner"> <p class="pupil"> <p class="light"></p> </p> </p> </p> <p class="eye eye-right extra-light"> <p class="eye-inner"> <p class="pupil"> <p class="light"></p> </p> </p> </p> </p> </p> /*第四只小青蛙眼珠另一个闪光点样式*/ .icon .frog .eyes .eye.extra-light .light {width: 40%;height: 40%;} .icon .frog .eyes .eye.extra-light .light:before {content: "";display: block;width: 70%; height: 70%;background-color: #fff;border-radius: 50%; }第四隻蛙蛙動圖.gif#剩餘的其它蛙蛙其它蛙蛙的畫法都是在基於通用樣式的基礎上對獨特樣式進行編寫,最重要的是對動畫幀的控制,各種形狀就是基本幾何圖形的拼接(正方形,border-radius,transform,position的合理運用)。 由於程式碼量太大我就不在文章裡贅述,主要還是動畫幀的熟練運用! (重要的事情說三次)。
以上是關於html如何打造動畫可愛的蛙蛙表情的案例分享的詳細內容。更多資訊請關注PHP中文網其他相關文章!