Nền tảng Kiến thức - Hành trang tới Tương lai
Card image

Chương 2-Bài 7. Thiết kế trang web bố cục (layout) tùy biến theo từng thiết bị màn hình (Responsive)

Tác giả: Dương Nguyễn Phú Cường #9805
Ngày đăng: Hồi xưa đó
Lượt xem: 880

Khái niệm về Responsive

Responsive là một tiêu chuẩn thiết kế trang web hiện đại. Cho phép bố cục (layout) trang web có thể co bóp tương ứng theo chiều rộng (Width) của thiết bị màn hình của người dùng đang truy cập trang web.

Kích thước chiều rộng (Width) của các màn hình chuẩn

Theo thiết kế của Bootstrap. Xem chi tiết tại: https://getbootstrap.com/docs/4.6/layout/overview/

Kích thước phân chia các cột trong Bootstrap

Bootstrap là framework theo tiêu chí Mobile first, có nghĩa là sẽ thiết kế theo tiêu chuẩn màn hình nhỏ nhất (là mobile), sau đó sẽ tăng dần lên các thiết bị có màn hình rộng hơn. Cách đặt tên class cho các cột trong Bootstrap:
  • .col-: có nghĩa là cột này sẽ đáp ứng cho thiết bị là mobile (khi để thẳng đứng).
  • .col-sm-: có nghĩa là cột này sẽ đáp ứng cho thiết bị là mobile (khi để mobile nằm ngang).
  • .col-md-: có nghĩa là cột này sẽ đáp ứng cho các thiết bị tablet như Ipad, Notebook, ...
  • .col-lg-: có nghĩa là cột này sẽ đáp ứng cho các thiết bị là màn hình máy tính desktop có kích thước 17 inch trở xuống
  • .col-xl-: có nghĩa là cột này sẽ đáp ứng cho các thiết bị là màn hình máy tính desktop có kích thước 19 inch trở lên

Ví dụ thiết kế layout tự co bóp theo thiết bị màn hình

Phân tích

1. Cột box 1, sẽ tùy biến theo màn hình:
  • Nếu là thiết bị mobile thì sẽ là cột 12 => cần áp dụng class col-12
  • Nếu là thiết bị tablet trở lên thì sẽ là cột 6 => cần áp dụng class col-md-6
  • Nếu là thiết bị desktop trờ lên thì sẽ là cột 3 => cần áp dụng class col-lg-3
=> Kết hợp tất cả ta sẽ có cột có thể tùy biến cho cả 3 thiết bị (nên viết code theo thứ tự áp dụng chiều rộng từ nhỏ đến lớn: mobile -> tablet -> desktop): col-12 col-md-6 col-lg-3 2. Cột box 2, sẽ tùy biến theo màn hình:
  • Nếu là thiết bị mobile thì sẽ là cột 12 => cần áp dụng class col-12
  • Nếu là thiết bị tablet trở lên thì sẽ là cột 6 => cần áp dụng class col-md-6
  • Nếu là thiết bị desktop trờ lên thì sẽ là cột 9 => cần áp dụng class col-lg-9
=> Kết hợp tất cả ta sẽ có cột có thể tùy biến cho cả 3 thiết bị (nên viết code theo thứ tự áp dụng chiều rộng từ nhỏ đến lớn: mobile -> tablet -> desktop): col-12 col-md-6 col-lg-9 3. Cột box 3, sẽ tùy biến theo màn hình:
  • Nếu là thiết bị mobile thì sẽ là cột 12 => cần áp dụng class col-12
  • Nếu là thiết bị tablet trở lên thì sẽ là cột 6 => cần áp dụng class col-md-6
  • Nếu là thiết bị desktop trờ lên thì sẽ là cột 3 => cần áp dụng class col-lg-3
=> Kết hợp tất cả ta sẽ có cột có thể tùy biến cho cả 3 thiết bị (nên viết code theo thứ tự áp dụng chiều rộng từ nhỏ đến lớn: mobile -> tablet -> desktop): col-12 col-md-6 col-lg-3 4. Cột box 4, sẽ tùy biến theo màn hình:
  • Nếu là thiết bị mobile thì sẽ là cột 12 => cần áp dụng class col-12
  • Nếu là thiết bị tablet trở lên thì sẽ là cột 6 => cần áp dụng class col-md-6
  • Nếu là thiết bị desktop trờ lên thì sẽ là cột 3 => cần áp dụng class col-lg-3
=> Kết hợp tất cả ta sẽ có cột có thể tùy biến cho cả 3 thiết bị (nên viết code theo thứ tự áp dụng chiều rộng từ nhỏ đến lớn: mobile -> tablet -> desktop): col-12 col-md-6 col-lg-3 5. Cột box 5, sẽ tùy biến theo màn hình:
  • Nếu là thiết bị mobile thì sẽ là cột 6 => cần áp dụng class col-6
  • Nếu là thiết bị tablet trở lên thì sẽ là cột 6 => cần áp dụng class col-md-6
  • Nếu là thiết bị desktop trờ lên thì sẽ là cột 3 => cần áp dụng class col-lg-3
=> Kết hợp tất cả ta sẽ có cột có thể tùy biến cho cả 3 thiết bị (nên viết code theo thứ tự áp dụng chiều rộng từ nhỏ đến lớn: mobile -> tablet -> desktop): col-6 col-md-6 col-lg-3 6. Cột box 6, sẽ tùy biến theo màn hình:
  • Nếu là thiết bị mobile thì sẽ là cột 6 => cần áp dụng class col-6
  • Nếu là thiết bị tablet trở lên thì sẽ là cột 6 => cần áp dụng class col-md-6
  • Nếu là thiết bị desktop trờ lên thì sẽ là cột 3 => cần áp dụng class col-lg-3
=> Kết hợp tất cả ta sẽ có cột có thể tùy biến cho cả 3 thiết bị (nên viết code theo thứ tự áp dụng chiều rộng từ nhỏ đến lớn: mobile -> tablet -> desktop): col-6 col-md-6 col-lg-3

Code mẫu

<!DOCTYPE html>
<html lang="vi">

<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <meta name="keywords" content="Nền tảng,HTML,CSS,XML,JavaScript, Lập trình C#, Lập trình, Web, Kiến thức, Đồ án">
  <meta name="author" content="Dương Nguyễn Phú Cường">
  <meta name="description"
    content="Cung cấp các kiến thức Nền tảng, cơ bản về Lập trình, Lập trình web, Lập trình di động, Cơ sở dữ liệu, ...">
  <meta property="og:locale" content="vi_VN">
  <meta property="og:type" content="website">
  <meta property="og:title" content="Nền tảng Kiến thức">
  <meta property="og:description"
    content="Cung cấp các kiến thức Nền tảng, cơ bản về Lập trình, Lập trình web, Lập trình di động, Cơ sở dữ liệu, ...">
  <meta property="og:url" content="https://nentang.vn/">
  <meta property="og:site_name" content="Nền tảng Kiến thức">
  <title>Học cách thiết kế layout responsive Bootstrap | NenTang.vn</title>

  <!-- Liên kết CSS Bootstrap -->
  <link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/bootstrap@4.6.0/dist/css/bootstrap.min.css"
    integrity="sha384-B0vP5xmATw1+K9KRQjQERJvTumQW0nPEzvF6L/Z6nronJ3oUOFUFpCjEUQouq2+l" crossorigin="anonymous">

  <style>
    /* Class quy định định dạng Khối DIV thứ 1 */
    .box1 {
      height: 200px;
      background-color: #FFE6CC;
      border: 3px solid #D79B00;
      color: #000;
    }

    /* Class quy định định dạng Khối DIV thứ 2 */
    .box2 {
      height: 200px;
      background-color: #DAE8FC;
      border: 3px solid #6C8EBF;
      color: #000;
    }

    /* Class quy định định dạng Khối DIV thứ 3 */
    .box3 {
      height: 200px;
      background-color: #60A917;
      border: 1px solid #2D7600;
      color: #fff;
    }
    
    /* Class quy định định dạng Khối DIV thứ 4 */
    .box4 {
      height: 200px;
      background-color: #D80073;
      border: 1px solid #A50040;
      color: #fff;
    }

    /* Class quy định định dạng Khối DIV thứ 5 */
    .box5 {
      height: 200px;
      background-color: #0050EF;
      border: 1px solid #001DBC;
      color: #fff;
    }

    /* Class quy định định dạng Khối DIV thứ 6 */
    .box6 {
      height: 200px;
      background-color: #A20025;
      border: 1px solid #6F0000;
      color: #fff;
    }
  </style>
</head>

<body>
  <div class="container">
    <div class="row">
      <!-- Cột box 1, sẽ tùy biến theo màn hình:
      - Nếu là thiết bị mobile thì sẽ là cột 12         => cần áp dụng class col-12
      - Nếu là thiết bị tablet trở lên thì sẽ là cột 6  => cần áp dụng class col-md-6
      - Nếu là thiết bị desktop trờ lên thì sẽ là cột 3 => cần áp dụng class col-lg-3
      => Kết hợp tất cả ta sẽ có cột có thể tùy biến cho cả 3 thiết bị 
      (nên viết code theo thứ tự áp dụng chiều rộng từ nhỏ đến lớn: mobile -> tablet -> desktop)
        col-12 col-md-6 col-lg-3
      -->
      <div class="box1 col-12 col-md-6 col-lg-3">Box 1</div>

      <!-- Cột box 2, sẽ tùy biến theo màn hình:
      - Nếu là thiết bị mobile thì sẽ là cột 12         => cần áp dụng class col-12
      - Nếu là thiết bị tablet trở lên thì sẽ là cột 6  => cần áp dụng class col-md-6
      - Nếu là thiết bị desktop trờ lên thì sẽ là cột 9 => cần áp dụng class col-lg-9
      => Kết hợp tất cả ta sẽ có cột có thể tùy biến cho cả 3 thiết bị 
      (nên viết code theo thứ tự áp dụng chiều rộng từ nhỏ đến lớn: mobile -> tablet -> desktop)
        col-12 col-md-6 col-lg-9
      -->
      <div class="box2 col-12 col-md-6 col-lg-9">Box 2</div>
    </div>

    <div class="row">
      <!-- Cột box 3, sẽ tùy biến theo màn hình:
      - Nếu là thiết bị mobile thì sẽ là cột 12         => cần áp dụng class col-12
      - Nếu là thiết bị tablet trở lên thì sẽ là cột 6  => cần áp dụng class col-md-6
      - Nếu là thiết bị desktop trờ lên thì sẽ là cột 3 => cần áp dụng class col-lg-3
      => Kết hợp tất cả ta sẽ có cột có thể tùy biến cho cả 3 thiết bị 
      (nên viết code theo thứ tự áp dụng chiều rộng từ nhỏ đến lớn: mobile -> tablet -> desktop)
        col-12 col-md-6 col-lg-3
      -->
      <div class="box3 col-12 col-md-6 col-lg-3">Box 3</div>

      <!-- Cột box 4, sẽ tùy biến theo màn hình:
      - Nếu là thiết bị mobile thì sẽ là cột 12         => cần áp dụng class col-12
      - Nếu là thiết bị tablet trở lên thì sẽ là cột 6  => cần áp dụng class col-md-6
      - Nếu là thiết bị desktop trờ lên thì sẽ là cột 3 => cần áp dụng class col-lg-3
      => Kết hợp tất cả ta sẽ có cột có thể tùy biến cho cả 3 thiết bị 
      (nên viết code theo thứ tự áp dụng chiều rộng từ nhỏ đến lớn: mobile -> tablet -> desktop)
        col-12 col-md-6 col-lg-3
      -->
      <div class="box4 col-12 col-md-6 col-lg-3">Box 4</div>

      <!-- Cột box 5, sẽ tùy biến theo màn hình:
      - Nếu là thiết bị mobile thì sẽ là cột 6          => cần áp dụng class col-6
      - Nếu là thiết bị tablet trở lên thì sẽ là cột 6  => cần áp dụng class col-md-6
      - Nếu là thiết bị desktop trờ lên thì sẽ là cột 3 => cần áp dụng class col-lg-3
      => Kết hợp tất cả ta sẽ có cột có thể tùy biến cho cả 3 thiết bị 
      (nên viết code theo thứ tự áp dụng chiều rộng từ nhỏ đến lớn: mobile -> tablet -> desktop)
        col-6 col-md-6 col-lg-3
      -->
      <div class="box5 col-6 col-md-6 col-lg-3">Box 5</div>

      <!-- Cột box 6, sẽ tùy biến theo màn hình:
      - Nếu là thiết bị mobile thì sẽ là cột 6          => cần áp dụng class col-6
      - Nếu là thiết bị tablet trở lên thì sẽ là cột 6  => cần áp dụng class col-md-6
      - Nếu là thiết bị desktop trờ lên thì sẽ là cột 3 => cần áp dụng class col-lg-3
      => Kết hợp tất cả ta sẽ có cột có thể tùy biến cho cả 3 thiết bị 
      (nên viết code theo thứ tự áp dụng chiều rộng từ nhỏ đến lớn: mobile -> tablet -> desktop)
        col-6 col-md-6 col-lg-3
      -->
      <div class="box6 col-6 col-md-6 col-lg-3">Box 6</div>
    </div>
  </div>
  

  <!-- Liên kết JavaScript Bootstrap -->
  <script src="https://code.jquery.com/jquery-3.5.1.slim.min.js"
    integrity="sha384-DfXdz2htPH0lsSSs5nCTpuj/zy4C+OGpamoFVy38MVBnE+IbbVYUew+OrCXaRkfj"
    crossorigin="anonymous"></script>
  <script src="https://cdn.jsdelivr.net/npm/bootstrap@4.6.0/dist/js/bootstrap.bundle.min.js"
    integrity="sha384-Piv4xVNRyMGpqkS2by6br4gNJ7DXjqk09RmUpJ8jgGtD7zP9yug3goQfGII0yAns"
    crossorigin="anonymous"></script>
</body>

</html>

Xem demo

Truy cập và thử điều chỉnh độ rộng của màn hình: http://frontend-basic.learning.nentang.vn/course-bootstrap/thiet-ke-layout-responsive/index.html

Chương trình học


  1. Tài liệu tham khảo 1
    1. Kho sách, nguồn tài liệu tham khảo Thiết kế Web với Bootstrap #8251
  2. Bootstrap là gì? Tìm hiểu cách hoạt động của Bootstrap 8
    1. Giới thiệu Bootstrap #2698
    2. Cách sử dụng Bootstrap trong dự án của bạn #2699
    3. Hệ thống Lưới (GRID) của Bootstrap #2700
    4. Bài tập - Thiết kế Bố cục (layout) bằng Bootstrap #2701
    5. Ràng buộc dữ liệu (validation) bằng Bootstrap #8270
    6. Bài tập Tổng hợp - Thực hiện Trang web Landing Page giới thiệu Công ty #8332
    7. Thiết kế trang web bố cục (layout) tùy biến theo từng thiết bị màn hình (Responsive) #9805
    8. Tùy biến giao diện theo từng thiết bị màn hình (Responsive) bằng kỹ thuật CSS Media Query #10114
  3. Làm Đồ án Web thực tế Trang bán hàng Nền Tảng phiên bản Bootstrap 14
    1. Lộ trình (Roadmap) Thực hiện Đồ án #10356
    2. Khởi tạo thư mục dự án #2702
    3. Phân tích Bố cục (layout) #2703
    4. Xây dựng Trang chủ (index) #2704
    5. Xây dựng Trang Giới thiệu (about) #2705
    6. Xây dựng Trang Liên hệ (contact) #2706
    7. Xây dựng Trang Danh sách Sản phẩm (products) #2707
    8. Xây dựng Trang Chi tiết Sản phẩm (product_detail) #2708
    9. Xây dựng Trang Giỏ hàng (cart) #2709
    10. Xây dựng Trang Thanh toán (checkout) #2710
    11. Xây dựng Trang Đăng nhập (login) #2711
    12. Xây dựng Trang Đăng ký (register) #2712
    13. Xây dựng Trang Tìm kiếm (search) #2713
    14. Thưởng thức Kết quả (demo version) #2714
Các bài học

Chương trình học

Bao gồm Module, Chương, Bài học, Bài tập, Kiểm tra...

Chương trình học


  1. Tài liệu tham khảo 1
    1. Kho sách, nguồn tài liệu tham khảo Thiết kế Web với Bootstrap #8251
  2. Bootstrap là gì? Tìm hiểu cách hoạt động của Bootstrap 8
    1. Giới thiệu Bootstrap #2698
    2. Cách sử dụng Bootstrap trong dự án của bạn #2699
    3. Hệ thống Lưới (GRID) của Bootstrap #2700
    4. Bài tập - Thiết kế Bố cục (layout) bằng Bootstrap #2701
    5. Ràng buộc dữ liệu (validation) bằng Bootstrap #8270
    6. Bài tập Tổng hợp - Thực hiện Trang web Landing Page giới thiệu Công ty #8332
    7. Thiết kế trang web bố cục (layout) tùy biến theo từng thiết bị màn hình (Responsive) #9805
    8. Tùy biến giao diện theo từng thiết bị màn hình (Responsive) bằng kỹ thuật CSS Media Query #10114
  3. Làm Đồ án Web thực tế Trang bán hàng Nền Tảng phiên bản Bootstrap 14
    1. Lộ trình (Roadmap) Thực hiện Đồ án #10356
    2. Khởi tạo thư mục dự án #2702
    3. Phân tích Bố cục (layout) #2703
    4. Xây dựng Trang chủ (index) #2704
    5. Xây dựng Trang Giới thiệu (about) #2705
    6. Xây dựng Trang Liên hệ (contact) #2706
    7. Xây dựng Trang Danh sách Sản phẩm (products) #2707
    8. Xây dựng Trang Chi tiết Sản phẩm (product_detail) #2708
    9. Xây dựng Trang Giỏ hàng (cart) #2709
    10. Xây dựng Trang Thanh toán (checkout) #2710
    11. Xây dựng Trang Đăng nhập (login) #2711
    12. Xây dựng Trang Đăng ký (register) #2712
    13. Xây dựng Trang Tìm kiếm (search) #2713
    14. Thưởng thức Kết quả (demo version) #2714

Bài học trước Bài học tiếp theo