Weekly UI – Hướng dẫn code giao diện trang sản phẩm đơn giản
Bài viết được sự cho phép của tác giả Trần Anh Tuấn
Hôm nay ngồi rãnh rỗi tranh thủ viết tiếp serie Weekly UI cho các bạn newbie. Hôm trước hướng dẫn làm form đăng nhập UI đơn giản rồi, hôm nay chuyển hướng sang làm trang sản phẩm về giày có tên là Jogger. Và các bạn cũng nhìn thấy trên ảnh đại diện rồi. Không chần chừ nữa, sau đây mình sẽ vào bước phân tích nó nhé.
# Phân tích
Layout: Nhìn vào giao diện mình thấy có ba phần riêng biệt đó là header trên cùng gồm có menu, logo chữ Shoes và các icon bên phải, phần thứ hai là navigation bên trái có các liên kết và icon mạng xã hội nằm theo chiều dọc và cuối cùng là phần chính Slider chiếm phần lớn giao diện.
Đặt tên class: Đây là trang sản phẩm thì các bạn có thể đặt tên class là .single__product
hoặc .product
thôi cho gọn cũng được. Đây là class cha bọc lại khi chúng ta code HTML.
Icons: Mình dùng font-awesome, có hỗ trợ trong Codepen luôn, các bạn vào Codepen chọn phần Setting rồi hiện ra giao diện như hình dưới đây, các bạn gõ vào font-awesome hiện ra chọn sau đó nhấn Save & Close là xong.
Fonts: Mình dùng font chữ Montserrat và Lobster từ Google, các bạn vào Google Fonts chọn 2 fonts chữ này rồi sau đó chèn vào chỗ để code CSS trên Codepen như sau:
@import url("https://fonts.googleapis.com/css?family=Montserrat:400,100, 300,700"); @import url('https://fonts.googleapis.com/css?family=Lobster');
Hình chiếc giày: Mình đã tìm Google và tách ảnh ra sẵn cho các bạn luôn. Các bạn có thể nhấn vào đây để tải về nhé.
Trong giao diện này mình sử dụng đơn vị REM để code, các bạn có thể tìm hiểu đơn vị REM tại đây. Ngoài ra mình còn sử dụng pseudo class như :before, :after, về cấu trúc layout mình dùng flexbox, có một điểm chú ý ở đây là ở phần navigation có các chữ nằm theo chiều dọc. Các bạn dùng thuộc tính này writing-mode: vertical-lr;
kết hợp với transform: rotate
cho các icon . Các bạn có thể tham khảo thêm ở đây.
Như vậy mình đã phân tích kỹ càng cho các bạn xong. Và đây là kết quả code HTML và CSS các bạn có thể tham khảo nhé.
# HTML
<div class="product"> <div class="product__header"> <div class="product__menu"><i class="fa fa-align-center product__menu-icon"></i><span class="product__menu-text">Menu</span></div> <h1 class="product__heading">Shoes</h1> <ul class="tool"> <li class="tool__item"><i class="far fa-heart"></i></li> <li class="tool__item"><i class="fas fa-search"></i></li> <li class="tool__item"><i class="fas fa-shopping-bag"></i></li> </ul> </div> <div class="product__nav"> <ul class="category"> <li class="category__item"><a class="category__link" href="javascript:void(0)">Brands</a></li> <li class="category__item"><a class="category__link" href="javascript:void(0)">Footwear</a></li> <li class="category__item"><a class="category__link" href="javascript:void(0)">Clothing</a></li> </ul> <div class="social"><span class="social__text">Follow us</span> <ul class="social__share"> <li class="social__share-item"><a class="social__share-link" href="javascript:void(0)"><i class="fab fa-facebook-f"></i></a></li> <li class="social__share-item"><a class="social__share-link" href="javascript:void(0)"><i class="fab fa-twitter"></i></a></li> </ul> </div> </div> <div class="product__slider"> <ul class="slider"> <li class="slider__item"> <h2 class="slider__title">Congo african product</h2> <div class="slider__img"><img src="https://preview.ibb.co/m4VkQd/congo.png" alt="Congo african product"/> <div class="slider__price">$79.00</div> </div> <button class="btn btn--secondary">Add to cart</button> </li> </ul> <ul class="slider__arrow"> <li class="slider__arrow-item is-active"><span>Next </span><span>→</span></li> <li class="slider__arrow-item"><span>Prev </span><span>←</span></li> </ul> </div> </div>
# CSS
@import url("https://fonts.googleapis.com/css?family=Montserrat:400,100, 300,700"); @import url("https://fonts.googleapis.com/css?family=Lobster"); *, *:before, *:after { box-sizing: border-box; } html { font-size: 62.5%; } img { display: block; max-width: 100%; } a { text-decoration: none; } body { font-family: "Montserrat", sans-serif; background-image: linear-gradient(to right, #5A3D57, #953c6c); background-repeat: no-repeat; background-size: cover; width: 100%; min-height: 100vh; overflow: auto; } .btn { border: 0; cursor: pointer; padding: 1.5rem; min-width: 20rem; color: white; text-transform: uppercase; box-shadow: 0 1rem 4rem rgba(0, 0, 0, 0.3); outline: none; font-family: "Montserrat"; -webkit-transform: translateY(-5px); transform: translateY(-5px); transition: .2s; } .btn:active { -webkit-transform: translateY(0); transform: translateY(0); box-shadow: 0 0.5rem 4rem rgba(0, 0, 0, 0.3); } .btn--secondary { background-color: #F3A74C; } .product { background-color: #BA426C; width: 95%; min-height: calc(100vh - 10rem); margin: 5rem auto; box-shadow: 0 1rem 4rem rgba(0, 0, 0, 0.2); overflow: hidden; position: relative; z-index: 10; } .product:before { content: "JOGGER"; position: absolute; top: 50%; left: 50%; -webkit-transform: translate(-50%, -50%); transform: translate(-50%, -50%); font-size: 18vw; font-weight: 700; z-index: -1; color: black; opacity: .025; } .product__header { display: flex; flex-direction: row; justify-content: space-between; align-items: center; } .product__heading { font-size: 2.5rem; color: white; font-family: "Lobster", sans-serif; } .product__menu { cursor: pointer; padding: 2rem 3rem; background-color: #60395C; color: white; text-transform: uppercase; display: flex; flex-direction: row; justify-content: center; align-items: center; } .product__menu-text { margin-left: 1rem; } .product__menu-icon { font-size: 1.6rem; } .product__nav { background-color: white; padding: 4rem 3rem; height: calc(100% - 5.6rem); position: absolute; top: 5.6rem; left: 0; display: flex; flex-direction: row; justify-content: space-between; align-items: center; -webkit-writing-mode: vertical-lr; -ms-writing-mode: tb-lr; writing-mode: vertical-lr; z-index: 20; } @media only screen and (max-width: 52em) { .product__nav { display: none; } } .product__nav .share__link i { -webkit-transform-origin: 50% 50%; transform-origin: 50% 50%; -webkit-transform: rotate(90deg); transform: rotate(90deg); } .product__nav.is-active { display: flex; } .product__slider { width: 100%; min-height: 100vh; position: relative; } .slider__img { margin-top: 2rem; margin-bottom: 2rem; } .slider__item { min-height: 100vh; padding: 4rem 1.5rem; text-align: center; display: flex; flex-direction: column; justify-content: space-between; align-items: center; } .slider__title, .slider__price { font-size: 4rem; color: white; text-transform: uppercase; font-weight: 700; } .slider__arrow { position: absolute; top: 50%; right: 0; -webkit-transform: translateY(-50%); transform: translateY(-50%); background-color: rgba(255, 255, 255, 0.1); box-shadow: -0.5rem 0 4rem rgba(0, 0, 0, 0.2); } .slider__arrow-item { cursor: pointer; padding: 3rem 2rem; text-transform: uppercase; color: white; text-align: center; } .slider__arrow-item span { display: block; margin-top: .25rem; margin-bottom: .25rem; } .slider__arrow-item.is-active { background-color: #F3A74C; } .category { display: flex; flex-direction: row; justify-content: center; align-items: center; } .category__item:not(:last-child) { margin-bottom: 2rem; } .category__link { color: black; text-transform: uppercase; text-decoration: none; font-weight: 700; transition: .2s; } .category__link:hover { color: #BA426C; } .social { display: flex; flex-direction: row; justify-content: space-between; align-items: center; } .social__text { text-transform: uppercase; font-weight: 700; margin-bottom: 2rem; } .social__share { display: flex flex-direction: row; justify-content: center; align-items: center; } .social__share-item:not(:last-child) { margin-bottom: 1rem; } .social__share-link { color: black; } .social__share-link i { -webkit-transform: rotate(90deg); transform: rotate(90deg); } .tool { padding: 0 3rem; display: flex; flex-direction: row; justify-content: center; align-items: center; } .tool__item { color: white; } .tool__item:not(:last-child) { margin-right: 1.5rem; }
# Tạm kết
Vậy là xong. Các bạn có thể xem kết quả tại Codepen mình ở đây nhé. Một lưu ý cho các bạn khi đọc tại blog mình, các UIs mình làm cho các bạn xem với mục đích tham khảo là chính, không hoàn toàn chính xác. Các bạn có thể học cách mình phân tích, cách code, lấy tài nguyên, cách đặt tên… để cải thiện thêm về kiến thức, kinh nghiệm của bản thân nhé.
Ngoài ra ở giao diện trên có Slider nhưng mình không code cho nó chạy, chỉ làm HTML và CSS mà thôi, các bạn có thể thử sức bằng cách thêm một thư viện Slider nào đó vào rồi làm thử xem nhen. Chúc các bạn học tập tốt và một ngày tốt lành.
Bài viết gốc được đăng tải tại evondev.com
Có thể bạn quan tâm:
- Webpack là gì? Hướng dẫn webpack 4: tất cả những gì bạn cần biết từ 0 đến khi ra sản phẩm
- Hướng dẫn tạo một đối thủ AI đơn giản cho cờ vua
- Hướng dẫn code game “Rắn săn mồi” bằng Python
Xem thêm các việc làm Developer hấp dẫn tại TopDev
- B BenQ RD Series – Dòng Màn Hình Lập Trình 4k+ Đầu Tiên Trên Thế Giới
- i iOS 18 có gì mới? Có nên cập nhật iOS 18 cho iPhone của bạn?
- G Gamma AI là gì? Cách tạo slide chuyên nghiệp chỉ trong vài phút
- P Power BI là gì? Vì sao doanh nghiệp nên sử dụng PBI?
- K KICC HCMC x TOPDEV – Bước đệm nâng tầm sự nghiệp cho nhân tài IT Việt Nam
- T Trello là gì? Cách sử dụng Trello để quản lý công việc
- T TOP 10 SỰ KIỆN CÔNG NGHỆ THƯỜNG NIÊN KHÔNG NÊN BỎ LỠ
- T Tìm hiểu Laptop AI – So sánh Laptop AI với Laptop thường
- M MySQL vs MS SQL Server: Phân biệt hai RDBMS phổ biến nhất
- S SearchGPT là gì? Công cụ tìm kiếm mới có thể đánh bại Google?