Professional Documents
Culture Documents
RWD
RWD
RESPONSIVE
WEB DESIGN
SEM I N A R
INTRO
PHÁT TRIỂN
ỨNG DỤNG WEB
NỘI DUNG
I RWD LÀ GÌ? II PHƯƠNG PHÁP THIẾT KẾ RWD
CONTENTS
RESPONSIVE WEB DESIGN KHÁI NIỆM
Là phong cách thiết kế trang web với bố cục, giao diện thẩm mỹ.
Trang web được nên duy trì sự hiển thị nội dung nhất quán, thẩm mỹ
trên mọi chế độ phân giải.
Sử dụng HTML - CSS để trang web tự động điều chỉnh kích thước, phóng
to, thu nhỏ, ẩn đi các phần tử.
DEFINITION
RESPONSIVE WEB DESIGN TẠI SAO?
Website mang tính thẩm mỹ, nhất quán, đồng bộ, tạo thiện cảm cho
người dùng.
Tiết kiệm thời gian và chi phí cho việc duy trì từng phiên bản
web khác nhau.
PERKS
PHƯƠNG PHÁP THIẾT KẾ
Flexible Media
Flexible
Grid Based Queries
Media
Layouts
METHODS
FLEXIBLE GRID BASED LAYOUTS PHƯƠNG PHÁP THIẾT KẾ
VIEWPORT
Là khung hình người dùng nhìn thấy trên thiết bị của họ khi vào một
trang web bất kì.
Nếu trang web cố định kích thước thì trình duyệt sẽ tự động thu nhỏ
nội dung khi chuyển từ màn hình máy tính qua smartphone - tạo nên trải
nghiệm không tốt cho người dùng.
VIEWPORT
FLEXIBLE GRID BASED LAYOUTS PHƯƠNG PHÁP THIẾT KẾ
VIEWPORT
HTML5 cung cấp cho chúng ta phương pháp kiểm soát view một cách dễ
dàng thông qua thẻ <meta>
thiết lập chiều rộng của trang web theo chiều rộng
của thiết bị
thiết lập mức độ zoom ban đầu khi trang web được
load bởi trình duyệt
VIEWPORT
FLEXIBLE GRID BASED LAYOUTS PHƯƠNG PHÁP THIẾT KẾ
VIEWPORT
VIEWPORT
FLEXIBLE GRID BASED LAYOUTS PHƯƠNG PHÁP THIẾT KẾ
GRID VIEW
Rất nhiều trang web được xây dựng trên grid view - trang web được
chia thành các cột đều nhau.
Một grid view thường có 12 cột ứng với 100% độ rộng và sẽ thu nhỏ hoặc
mở rộng khi bạn thay đổi kích thước trình duyệt.
Việc sử dụng grid view sẽ giúp bạn dễ dàng đặt vị trí các phần tử trên
trang hơn, thuận lợi cho việc thực hiện responsive về sau.
GRID VIEW
FLEXIBLE GRID BASED LAYOUTS PHƯƠNG PHÁP THIẾT KẾ
GRID VIEW
GRID VIEW
FLEXIBLE GRID BASED LAYOUTS PHƯƠNG PHÁP THIẾT KẾ
GRID VIEW
.container { section {
width: 538px; float: left; Các phần tử được giữ cố định
} width: 340px;
section, } Khi thay đổi kích thước container
aside { aside { thì kích thước các phần tử bên trong
margin: 10px; float: right; không thay đổi
} width: 158px;
}
GRID VIEW
FLEXIBLE GRID BASED LAYOUTS PHƯƠNG PHÁP THIẾT KẾ
GRID VIEW
.container { section {
width: 538px; float: left;
} width: 63.197026%;
Sử dụng % hoặc em để giúp các
,section, }
phần tử thay đổi theo kích thước
aside { aside {
của container
margin: float: right;
1.858736059%; width: 29.3680297%;
} }
GRID VIEW
FLEXIBLE GRID BASED LAYOUTS PHƯƠNG PHÁP THIẾT KẾ
GRID VIEW
<div class="row">
<div class="col-3">...</div> <!-- 25% -->
<div class="col-9">...</div> <!-- 75% -->
</div>
GRID VIEW
FLEXIBLE GRID BASED LAYOUTS PHƯƠNG PHÁP THIẾT KẾ
GRID VIEW
GRID VIEW
MEDIA QUERIES PHƯƠNG PHÁP THIẾT KẾ
Ta sử dụng cú pháp @media để bao gồm một khối các thuộc tính CSS chỉ
khi một điều kiện nhất định là đúng.
Nói một cách đơn giản là ta sẽ định nghĩa CSS riêng cho một nhóm các
thiết bị có kích thước giống nhau.
QUERIES
MEDIA QUERIES PHƯƠNG PHÁP THIẾT KẾ
Media Queries có thể được sử dụng trực tiếp trong thẻ HTML hoặc viết
bên trong file css.
OPERATIONS
MEDIA QUERIES PHƯƠNG PHÁP THIẾT KẾ
Media Queries có thể được sử dụng trực tiếp trong thẻ HTML hoặc viết
bên trong file css.
@media not screen and (min-width: 740px) and (max-width: 1023px) {...}
`not` trong media queries phủ định truy vấn được xác định.
Ví dụ trên KHÔNG áp dụng cho màn hình với chiều dài từ 740px - 1023px
OPERATIONS
MEDIA QUERIES PHƯƠNG PHÁP THIẾT KẾ
Media Queries có thể được sử dụng trực tiếp trong thẻ HTML hoặc viết
bên trong file css.
@media only screen and (min-width: 740px) and (max-width: 1023px) {...}
`only` trong media queries áp dụng cho truy vấn thỏa mãn điều kiện.
Ví dụ trên CHỈ áp dụng cho màn hình với chiều dài từ 740px - 1023px
OPERATIONS
MEDIA QUERIES PHƯƠNG PHÁP THIẾT KẾ
MEDIA FEATURES
Media features xác định các thuộc tính hoặc thành phần nào sẽ được
nhắm tới trong media queries.
ORIENTATION
ASPECT RATIO
RESOLUTION
FEATURES
MEDIA QUERIES PHƯƠNG PHÁP THIẾT KẾ
MEDIA FEATURES
HEIGHT & WIDTH
Là một trong những media feature phổ biến nhất trong việc xác định
chiều cao và chiều rộng cho viewport.
Giá trị của height hoặc width có thể là đơn vị độ dài, tương đối hoặc
tuyệt đối. Chúng còn thường được đi kèm với các tiền tố min và max.
H&W
MEDIA QUERIES PHƯƠNG PHÁP THIẾT KẾ
MEDIA FEATURES
ORIENTATION
Là media feature dùng để xác định hướng của browser, thiết bị:
landscape - hướng ngang | portrait - hướng dọc.
Tính năng này được áp dụng chủ yếu trên các thiết bị di động.
ORIENTATION
MEDIA QUERIES PHƯƠNG PHÁP THIẾT KẾ
MEDIA FEATURES
ASPECT RATIO
Là media feature cho phép ta chỉ định tỉ lệ chiều rộng/chiều cao của
thiết bị.
Tính năng này thường đi kèm với các tiền tố min và max.
RATIO
MEDIA QUERIES PHƯƠNG PHÁP THIẾT KẾ
MEDIA FEATURES
RESOLUTION
Là media feature chỉ định độ phân giải của thiết bị đầu ra theo mật độ
pixel, còn được gọi là điểm ảnh trên mỗi inch (DPI - Dots Per Inch).
Tính năng này không đi kèm với các tiền tố min và max mà thay vào đó là
số điểm ảnh trên mỗi pixel dppx và số điểm ảnh trên cm dpcm.
RESOLUTION
MEDIA QUERIES PHƯƠNG PHÁP THIẾT KẾ
DEMO
DEMO
FLEXIBLE MEDIA PHƯƠNG PHÁP THIẾT KẾ
Khi mà viewport thay đổi kích thước thì các đa phương tiện
(ảnh, video,..) cũng cần có khả năng thay đổi sao cho phù hợp.
UI/UX rất được coi trọng trong việc thiết kế và phát triển web, vì
người dùng càng ngày càng sử dụng các thiết bị di dộng nhiều hơn.
RULES
NGUYÊN TẮC RWD 02
- Luôn luôn là Mobile First -
Thực hiện layout cho điện thoại di động trước máy tính để bàn hoặc bất
kỳ thiết bị nào khác giúp trang web hiển thị nhanh hơn trên các thiết
bị nhỏ hơn.
RULES
NGUYÊN TẮC RWD 02
- Luôn luôn là Mobile First -
Mục đích khi làm responsive là hướng đến người dùng các thiết bị di
động, với cấu hình yếu hơn PC/laptop, và có màn hình nhỏ hơn.
RULES
NGUYÊN TẮC RWD 02
- Luôn luôn là Mobile First -
/* Cho điện thoại di động: */ Ưu tiên chạy qua đoạn tất cả các
[class*="col-"] {
thẻ có class có tiền tố là col- và
width: 100%;
} đặt width: 100% cho các thẻ này.
{...}
RULES
NGUYÊN TẮC RWD 03
- Hiển thị nội dung kiểu dòng chảy (flow) -
Cho dù một mẫu điện thoại có màn hình lớn đi chăng nữa thì dĩ nhiên nó
vẫn khá nhỏ so với PC.
RULES
NGUYÊN TẮC RWD 04
- Sử dụng các breakpoints hợp lý -
Liệt kê ra mọi breakpoints tương ứng với kích thước của các thiết bị
di động hiện nay và chọn ra những breakpoints phổ biến nhất để thực
hiện responsive cho các thiết bị này.
RULES
NGUYÊN TẮC RWD 04
- Sử dụng các breakpoints hợp lý -
Ví dụ, các thiết bị tablets thường có độ phân giải chiều rộng tối đa
là 992px, thì khi làm responsive ta chỉ lấy breakpoints này làm mốc và
viết CSS trong đó.
RULES
NGUYÊN TẮC RWD 05
- Sử dụng các giá trị tương đối
thay vì giá trị tuyệt đối -
Nên sử dụng các giá trị tương đối (%) cho việc đặt width hoặc height
cho các phần tử hiển thị trên mobile.
Hạn chế sử dụng các giá trị tuyệt đối (px, em, ...) vì chúng sẽ không
thể tự resize theo chiều rộng/ngang của thiết bị được.
@media only screen and (max-width: 992px) { @media only screen and (max-width: 992px) {
.image { .image {
width: 100%; NÊN width: 500px; KHÔNG NÊN
} }
} }
RULES
NGUYÊN TẮC RWD 06
- Hạn chế khoảng trống, giảm độ lớn
font chữ và lược bỏ quảng cáo -
Các phần tử, font chữ trên desktop khi hiển thị sẽ có khoảng cách và
độ lớn cao để tạo không gian thoải mái cho người dùng.
Không còn phù hợp trên các thiết bị di động nữa, khoảng
trống và font chữ quá lớn sẽ gây khó chịu cho người dùng.
RULES
NGUYÊN TẮC RWD 06
- Hạn chế khoảng trống, giảm độ lớn
font chữ và lược bỏ quảng cáo -
Các thiết bị di động có kích thước khá nhỏ nên người dùng cần hiển thị
đầy đủ thông tin hơn là xem các banner quảng cáo.
AD
AD
RULES
ƯU ĐIỂM ƯU - NHƯỢC ĐIỂM
Nâng cao trải nghiệm người dùng, có thể truy cập website từ mọi
thiết bị mà không gặp trở ngại về mặt giao diện.
Tiết kiệm thời gian quản lý vì chỉ cần quản lý một website duy
nhất và ít phải bảo dưỡng hơn
Tiết kiệm chi phí, không phải xây dựng nhiều website cho nhiều
thiết bị
PROS
NHƯỢC ĐIỂM ƯU - NHƯỢC ĐIỂM
Mất nhiều thời gian và công sức hơn khi thiết kế web responsive
so với trang web bình thường.
Khi lược giảm dữ liệu, kích thước hình ảnh sẽ làm mất đi các
thông tin và ý nghĩa muốn thể hiện và truyền đạt.
Thanh menu hiển thị trên điện thoại sẽ bị rối nếu có quá nhiều
navigation bar ở bản máy tính.
CONS
PHÁT TRIỂN IS207
ỨNG DỤNG WEB O21
CÁM ƠN
THẦY VÀ CÁC BẠN ĐÃ CHÚ Ý LẮNG NGHE!
END