介紹
成品
運用css可以做出許多意想不到的效果,有立體的呈現、動畫的改變等等…
- 漢堡表單的製作,以及點選時頁面的跳轉、動畫的改變
- nav按鈕,立體翻轉
- 中間icon圖示的排版,以及旋轉的效果
data:image/s3,"s3://crabby-images/d1496/d149672747d5a49983187ede4f5228a610f28039" alt=""
banner區的架構
1 2 3 4 5 6 7 8
| <div class="banner"> <div class="logo"> <a href="#"><img src="./hamburger-images/logo.png" alt=""></a> </div> <div class="btn-wrapper"> <button class="banner-btn">Explore More</button> </div> </div>
|
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28
| <nav class="top-nav"> <ul class="nav-list"> <li> <a href="#" class="nav-link" data-text='Home'>Home</a> </li> <li> <a href="#" class="nav-link" data-text='About As'>About As</a> </li> <li> <a href="#" class="nav-link" data-text='Our Team'> Our Team </a> </li> <li> <a href="#" class="nav-link" data-text='Services'> Services </a> </li>
<li> <a href="#" class="nav-link" data-text='Contanct'> Contanct </a> </li>
</ul> </nav>
|
data:image/s3,"s3://crabby-images/50f23/50f23af818f8b3c278562da16b992b743a9458e3" alt=""
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16
| <nav class="bottom-nav"> <ul class="icons"> <li class="icon-item"> <a href="#" class="icon-link"><i class="fab fa-facebook-f"></i></a> </li> <li class="icon-item"> <a href="#" class="icon-link"><i class="fab fa-youtube"></i></a> </li> <li class="icon-item"> <a href="#" class="icon-link"><i class="fab fa-twitter"></i></a> </li> <li class="icon-item"> <a href="#" class="icon-link"><i class="fab fa-google-plus-g"></i></a> </li> </ul> </nav>
|
data:image/s3,"s3://crabby-images/972a1/972a1052159131ee953827a880374b4e13606d64" alt=""
先讓nav列hidden起來
- 再html的class後面,增加hidden,瀏覽器就不會顯示該隱藏的部分
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33
| <nav class="top-nav" hidden> <ul class="nav-list"> <li> <a href="#" class="nav-link">Home</a> </li> <li> <a href="#" class="nav-link">About As</a> </li> <li> <a href="#" class="nav-lik"> Our Team </a> </li> <li> <a href="#" class="nav-link"> Services </a> </li>
<li> <a href="#" class="nav-link"> Contanct </a> </li>
</ul> </nav>
</div>
|
data:image/s3,"s3://crabby-images/82ef7/82ef77bd647c541c9c26bb80f1676c8f72d06aaa" alt=""
右上選單
先製作三個div
data:image/s3,"s3://crabby-images/8f9a3/8f9a375133e74b2c8d05306546432568614fb69f" alt=""
1 2 3 4 5
| <div class="hamburger-menu"> <div class="line line-1"></div> <div class="line line-2"></div> <div class="line line-3"></div> </div>
|
針對div的line設定
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19
| .hamburger-menu{ width: 35px; height: 30px; background-color: #fff; position: fixed; top: 40px; right: 50px; }
.line{ width: inherit; height: 5px; background-color: #16c3cf; border-radius: 25px; } .line-2{ background-color: #000; }
|
他是三個div組合的
這裏故意把2設為黑色
data:image/s3,"s3://crabby-images/fb95e/fb95e1e5c2b8ccda4a3f5d163b6a14d833cf988d" alt=""
- 讓他分三條線可以分散對齊
- 把白色去掉
1 2 3 4 5 6 7 8
| .hamburger-menu{ display: flex; flex-direction: column; justify-content: space-between; cursor: pointer; }
|
data:image/s3,"s3://crabby-images/83061/830610b0e10ccadcc1451c74e719575ef505318b" alt=""
3D按鈕
1 2 3 4 5 6
| .banner-btn{ width: 350px; height: 100px; background: linear-gradient(#16c3cf,#156459); }
|
data:image/s3,"s3://crabby-images/3c567/3c567899322ca23b44afd466cb74eae35026d770" alt=""
text-shadow: 0 10px 10px #000;
參考資料:
:::success
我們會在要進行3D變形的外層容器元素來定義perspective,這樣包含在其內的子元素(物件)都可以按照這個深度來進行變形。
perspective設定為300px或更少時,會有強烈的失真,500px到1000px的失真較為中等,2000px以上的失真就很輕微。
:::
1 2 3 4 5 6 7 8
| .banner-btn::before{ content: ''; width: 100%; height: 15px; background-color: red; position: absolute;
}
|
data:image/s3,"s3://crabby-images/36867/36867ccbbc6bdfdcb2d5e906cfc089007116e266" alt=""
1 2 3 4 5 6 7 8 9 10 11 12 13 14
| .banner-btn::before{ content: ''; width: 100%; height: 15px; background-color: #156469; position: absolute; bottom: 0px; right: 0px;
transform: rotateX(90deg);
transform-origin:bottom ;
}
|
data:image/s3,"s3://crabby-images/20e4f/20e4f989e47c018726f3709a5a650d91826552da" alt=""
transform-style: preserve-3d;
data:image/s3,"s3://crabby-images/336b6/336b6984895f0805254987c37194ae14a584a32b" alt=""
transform-origin:bottom ;
data:image/s3,"s3://crabby-images/227d4/227d4e4f50910c472affd0dfe90cef10beee0d5f" alt=""
data:image/s3,"s3://crabby-images/846df/846df409203d6f7657d828875c5b13cbe6546268" alt=""
1 2 3 4 5 6 7 8 9 10 11 12 13 14
| .banner-btn::after{ content: ''; width: 15px; height: 100%; background-color: #16c3cf; position: absolute; top: 0px; right: 0px;
transform: rotateY(-90deg);
transform-origin:right;
}
|
data:image/s3,"s3://crabby-images/5f092/5f09264ffc0b42ada8a25672e8fd5cd415856751" alt=""
nav列
- z-index:100
data:image/s3,"s3://crabby-images/69af0/69af0a462ebfcbaed1e10089c5cb7bef21c074c5" alt=""
data:image/s3,"s3://crabby-images/3bd8c/3bd8cc4ee8adb89df7365d254066020e2808a5f2" alt=""
在上層導覽列,先設定灰色的背景,以方便看清楚大小
使用flex排列
1 2 3 4 5 6 7 8 9 10 11 12 13 14
| .nav-list{ background-color: #ccc; list-style: none; width: 80%; margin: auto; height: inherit;
display: flex; justify-content: space-evenly; align-items:center;
}
|
data:image/s3,"s3://crabby-images/4146c/4146c39121d73d5657dc0593794d76a312755654" alt=""
上層導覽列,連結的3d按鈕製作
- 在他們的html 設定data-text
1 2
| <li> <a href="#" class="nav-link" data-text='Home'>Home</a> </li>
|
1 2 3 4 5 6 7 8
| .nav-link::after{ content: attr(data-text); position: absolute; left:0; bottom:-100%; background-color: #000; padding: inherit; }
|
data:image/s3,"s3://crabby-images/ddcb8/ddcb8e3934302bd6c92bc308888a70c07223c370" alt=""
將after創造出的rotate到父層元素的下方
1 2 3
| .nav-link:hover{ transform: rotateX(90deg); }
|
data:image/s3,"s3://crabby-images/0d25f/0d25f84c328b28d3e33d03b175fd88991b128259" alt=""
位置不對:
data:image/s3,"s3://crabby-images/3d829/3d829cf8debf60d4d90aab8d5760cd3d68b52e93" alt=""
data:image/s3,"s3://crabby-images/c5c8c/c5c8c976f786985496aa5682b3bbedc3df272780" alt=""
data:image/s3,"s3://crabby-images/182b8/182b8334aff5752cc7c321d07b9db2d15f43474f" alt=""
1 2 3 4 5 6
| .icons{ position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%);
|
data:image/s3,"s3://crabby-images/1ba2b/1ba2b37467b29cfa947a692a3318227518354eef" alt=""
data:image/s3,"s3://crabby-images/126fb/126fb6559a7c8b7a448c021aef9fd0d817518ec7" alt=""
1 2 3 4 5 6 7
| .icons{ display: flex;
width: 60%; justify-content: space-between;
}
|
data:image/s3,"s3://crabby-images/fc323/fc323d8054d3962dc5631c116a05272ecd7522ce" alt=""
data:image/s3,"s3://crabby-images/daee3/daee355f10dc19dcba10496671924eb2f10a490b" alt=""
上面因為原本為inline元素, display:block
或display:flex
data:image/s3,"s3://crabby-images/3baa9/3baa9911517f3ef69965ab85e437cf0d480bc7cf" alt=""
1 2 3 4 5 6 7 8 9 10 11 12 13 14
| .icon-link{ width: 200px; height: 200px;
border:8px solid #fff ;
display: flex; justify-content:center; align-items: center; text-decoration: none;
border-radius: 5px; }
|
data:image/s3,"s3://crabby-images/b008d/b008d584685816fbcb064f18d8d1aa1dee5f5d1f" alt=""
data:image/s3,"s3://crabby-images/ac42f/ac42ff51548fd330bed50c8a707230417f9d2e8a" alt=""
data:image/s3,"s3://crabby-images/e789e/e789edb784b082933ad0460147361c36c0116b5f" alt=""
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21
| .icon-link::before{ content: ''; height:25px ; width: 5px; background-color: #fff; position: absolute; top: 0;
}
.icon-link::after{ content: ''; height:25px ; width: 5px; background-color: #fff; position: absolute; bottom: 0;
}
|
data:image/s3,"s3://crabby-images/c7673/c7673e4d97d276757b190d4f87ba0fac3f257c78" alt=""
背景顏色的動畫
1.在icon後面增設背景色彩
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17
| .icon-item:nth-child(1) .icon-link i::after{ background-color: #3b5999; }
.icon-item:nth-child(2) .icon-link i::after{ background-color: #cd201f; }
.icon-item:nth-child(3) .icon-link i::after{ background-color: #55acee; }
.icon-item:nth-child(4) .icon-link i::after{ background-color: #dd4b39; }
|
2.設定hover之後,位置移動到原本icon的位置
1 2 3 4 5 6 7
| .icon-link:hover i::after{ top: 0; right: 0; border-radius: 0;
}
|
data:image/s3,"s3://crabby-images/764ea/764ea9f490acbdc8ff6af44c2d83f5bccba6fb15" alt=""
3.讓圓形色彩隱藏
1 2 3
| .icon-link i{ over-flow:hidden; }
|
data:image/s3,"s3://crabby-images/581d9/581d97f0c1e5340eff4253c1be66fd7875f669cf" alt=""
漢堡的動畫
- line-1,line-2,line-3 位置改變的設定
- 這裏使用js,增加change的class名稱
data:image/s3,"s3://crabby-images/36745/36745d087210767c755b3809c1c2eb0a79c9d52e" alt=""
data:image/s3,"s3://crabby-images/f1792/f17920203fa1989900f2d51b0ad79b2d8d395bdd" alt=""
1 2 3 4 5 6 7 8 9 10 11 12
| .change .line-1{ transform: rotateZ(-45deg); }
.change .line-2{ transform: translate(5px,20px); }
.change .line-3{ transform: rotateZ(45deg); }
|
1 2 3
| document.querySelector('.hamburger-menu').addEventListener('click', () => { document.querySelector('.nav-wrapper').classList.toggle('change') })
|
resposive
Day22:小事之 Media Query
響應式網站設計基本觀念(2):CSS媒體查詢(CSS Media Queries)