- vừa được xem lúc

Một số tips nhỏ khi làm việc với CSS

1 1 12

Người đăng: Bui Hoang Ky

Theo Viblo Asia

Hề nhô , hôm này mình ngoi lên để chia sẻ một số tips hay hay, mong anh em hãy ủng hộ mình nhé.

Bắt đầu nào

1.Set margin và padding rồi sau đó reset

Có bao giờ bạn căn margin và padding cho tất cả các element rồi sau đó reset chúng ở đầu hay cuối element chưa ? Công đoạn đó rất là mất thời gian đúng không, thay vào đó, tại sao chúng tạ lại không sử dụng cách dễ dàng và thuận tiện hơn này : dung thằng selectors nth-child/nth-of-type , dùng pseudo-class :not(), hoặc là dùng dấu + nè .

Trước nhé :

.item { margin-right: 1.6rem;
} .item:last-child { margin-right: 0;
}
// trông hơi rắc rối nhỉ 

Chúng ta nên làm như thế này :

Cách 1 :
.item:not(:last-child) { margin-right: 1.6rem;
} Cách 2 :
.item:nth-child(n+2) { margin-left: 1.6rem;
} Cách 3:
.item + .item { margin-left: 1.6rem;
}

2.Add display: block cho elements khi sử dụng cùng position: absolute hay position: fixed

Bạn có biết rằng chúng ta không cần add display: block cho elements khi sử dụng position: absolute hay position: fixed bởi vì nó đã được default ???

Đừng làm như thế này nhé :

.button::before { content: ""; position: absolute; display: block;
}

Hay như thế này :

.button::before { content: ""; position: fixed; display: block;
}

Nên làm như thế này :

.button::before { content: ""; position: absolute;
}

Và thế này này :

.button::before { content: ""; position: fixed;
}

3. Sử dụng transform: translate (-50%, -50%) để căn giữa

Đây là một vấn đề phổ biến đã từng gây ra rất nhiều nhức nhối. Nó kéo dài cho đến năm 2015, và tất cả các giải pháp của nó đều dẫn đến một số khó khăn: đó là căn giữa một phần tử có chiều cao tùy ý dọc theo hai trục.

Có một giải pháp đó là sử dụng thuộc tính position: absolute kết hợp với transform. Nhưng cách này thì lại gặp một vấn đề, nó sẽ làm mờ văn bản trên trình duyệt Chorme.

Sau đó chúng ta có sự ra đợi của thuộc tính flex box. Nhưng theo mình thì cũng không giải quyết được gì vẫn bị mờ text. Chính vì vậy mình sẽ đưa cho mọi người một tricks chỉ sử dụng 2 thuộc tính thôi nhé :

.parent { display: flex;
} .child { margin: auto;
}

Chứ đừng làm như thế này :

.parent { position: relative;
} .child { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%);
}

4. Sử dụng width: 100% cho Block Elements

Chúng ta thường sử dụng flexbox để tạo multi-column grid sau đó chuyeerm đổi thành một columi suy nhất

Và để chuyển đổi grid thành một column, chúng ta sử dụng width: 100%. Sao lại phải làm như thế này nhỉ ? Các grid elements là các elements khối có thể thực hiện việc này một cách mặc định mà không cần sử dụng các thuộc tính bổ sung. Vì vậy, chúng ta không cần thiết phải sử dụng width: 100%:

Đừng làm thế này nhé :

<div class="parent"> <div class="child">Item 1</div> <div class="child">Item 2</div> <div class="child">Item 3</div> <div class="child">Item 4</div>
</div>
.parent { display: flex; flex-wrap: wrap;
} .child { width: 100%;
} @media (min-width: 1024px) { .child { width: 25%; }
}

Nên làm như thế này :

<div class="parent"> <div class="child">Item 1</div> <div class="child">Item 2</div> <div class="child">Item 3</div> <div class="child">Item 4</div>
</div>
@media (min-width: 1024px) { .parent { display: flex; flex-wrap: wrap; } .child { width: 25%; }
}

5. Set display: block cho Flex Items

Khi sử dụng flexbox, điều quan trọng cần nhớ là khi bạn tạo flex container (thêm thuộc tính display: flex), tất cả các thằng con (flex items) sẽ bị chặn.

Điều này có nghĩa là các elements được thiết lập để hiển thị và chỉ có thể có các block valuesVậy nên, nếu bạn đặt inline hoặc inline-block, nó sẽ chuyển thành block, inline-flex -> flex, inline-grid -> gridinline-table -> table.

Vì vậy,đừng nhét thằng display: block vào flex items làm gì. Trình duyệt nó sẽ tự làm :v.

Đừng thế này nha :

.parent { display: flex;
} .child { display: block;
}

Như thế này thì chuẩn :


.parent { display: flex;
}

Kết bài

Vậy là các típ chia sẻ của mình lại kết thúc rồi .

Nếu thấy hay các bạn hay like, shareupvote dùm mình nhé ???

Many thanksssssss ???

Bình luận

Bài viết tương tự

- vừa được xem lúc

Căn giữa các phần tử HTML theo chiều dọc (phần 1)

Bài viết được dịch từ bài Vertical centering of elements in HTML xuất bản ngày 18/01/2015 trên trang Web++. .

0 0 79

- vừa được xem lúc

Căn giữa phần tử trong CSS

1. Theo chiều ngang. Đó có phải là phần tử inline hay inline-* (như text hay links). .

0 0 66

- vừa được xem lúc

99% không biết đến mẹo này khi sử dụng Flexbox CSS

Hello lại là mình đây. Bài viết hôm nay mình sẽ giới thiệu tới mọi người một trick khá hay khi dùng CSS flexbox nhé. 1. Chia layout với flexbox.

0 0 62

- vừa được xem lúc

Vanilla JS Project: Tính tuổi

1. Yêu cầu.

0 0 72

- vừa được xem lúc

1 số UI component và layout hữu ích với Frontend

Giới thiệu. Hôm nay mình xin chia sẻ 1 số Layout và UI component quen mà có lẽ là quen thuộc với nhiều người khi làm dự án, hay bắt gặp trên mạng.

0 0 65

- vừa được xem lúc

Style text css

Giới thiệu. Chào 2021, mình sẽ giới thiệu vài kiểu style cho text màu mè chút cho rực rỡ .

0 0 44