Thông tin liên hệ
- 036.686.3943
- admin@nguoicodonvn2008.info
Tạo pháo hoa bằng CSS khá đơn giản. Dưới đây là chi tiết cách tạo hiệu ứng pháo hoa với CSS.
Ý tưởng ở đây là tạo một phần tử nhỏ với background có kích thước tuyệt đối được đặt ở những vị trí tương đối khác nhau. Sử dụng tương đối và tuyệt đối là cần thiết ở đây.
Background tuyệt đối có nghĩa kích thước của chúng sẽ không thay đổi theo kích thước của container, nhưng vị trí sẽ là tương đối. Do đó, nó sẽ thay đổi khi container được chỉnh lại kích thước.
Khoảng cách tương đối giữa các chấm luôn giống nhau. Nhưng khi container mở rộng, khoảng cách tuyệt đối giữa chúng cũng mở rộng để hiệu ứng pháo hoa giống thật.

Nhìn vào hình tròn ở bên phải được chỉ bởi mũi tên. Vị trí của nó là 100% theo chiều ngang và 50% theo chiều dọc. Tỷ lệ này vẫn được giữ nguyên khi container thay đổi.
Như đã đề cập ở trên, phần HTML đơn giản. Chúng ta chỉ cần một phần tử cho mỗi firework:
<div class="firework"></div>
Nếu muốn kèm hình ảnh để tăng thêm hiệu ứng thị giác, bạn có thể thêm thẻ img và một aria-label kèm mô tả ngắn.
Bắt đầu bằng cách xác định các kiểu cơ bản cho pháo hoa. Một container chứa khối đơn giản nằm trên màn hình:
.firework {
position: absolute;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
width: 0.5vmin;
aspect-ratio: 1;
background:
/* background intentionally blank */
;
background-size: 0.5vmin 0.5vmin;
background-repeat: no-repeat;
}
Giải thích chi tiết thuộc tính và giá trị:
position: absolute;: Phần tử sẽ được di chuyển xung quanh màn hình. Vị trí tuyệt đối là lý tưởng để không ảnh hưởng tới các thành phần khác.top: 50%; left: 50%;: là mặc định. Firework là nằm ở vị trí trung tâm tuyệt đối. Bạn có thể thay đổi điều đó sau.transform: translate(-50%, -50%);: Điều này quan trọng. Bằng cách biên dịch phần tử -50% theo chiều ngang và dọc, nó sẽ mở rộng theo tất cả các hướng khi bạn thay đổi kích thước.width: 0.5vmin; aspect-ratio: 1;: phần tử này sẽ là một hình vuông nhỏ. Ở đây dùng đơn vị vmin vì nó đáp ứng nhưng bạn có thể dùng px, rem hoặc đơn vị CSS yêu thích.background-size: 0.5vmin 0.5vmin;: Quan trọng. Ví dụ thiết lập một kích thước background cố định nên khi xác định gradient, chúng sẽ luôn có cùng kích thước, không phụ thuộc vào kích thước của container.background-repeat: no-repeat;: Không lặp lại gradient để tránh rối mắt.Đối với background, ví dụ thêm một loạt gradient tỏa tròn:
radial-gradient(circle, yellow 0.5vmin, #0000 0) 50% 0%
Gradient sẽ đặt một hình tròn kích thước 0.5vmin ở trung tâm (50%), trên (0%) của phần tử pháo hoa. Đảm bảo bạn phân bổ chúng trên khắp container.
Hoạt ảnh sẽ được chia thành 2 phần: pháo hoa bay lên bầu trời và nổ pháo hoa.
@keyframes firework {
0% {
transform: translate(-50%, 60vh);
width: 0.5vmin;
opacity: 1;
}
50% {
width: 0.5vmin;
opacity: 1;
}
100% {
width: 45vmin;
opacity: 0;
}
}
Code này sẽ di chuyển pháo hoa ra ngoài phía dưới cùng của màn hình (translate(-50%, 60vh)), giữ nó nhỏ (width: 0.5vmin) và hiện (opacity: 1).
Một nửa hoạt ảnh, các phần tử hiển thị vẫn nhỏ, sau đó, nó mở rộng tới kích thước cuối cùng (45vmin) và hợp nhất với nền.
.firework {
animation: firework 2s infinite;
...
}
Cuối cùng, áp dụng các kiểu tương tự cho pseudo-elements ::before và ::after của pháo hoa.
.firework,
.firework::before,
.firework::after {
content: "";
...
}
.firework::before {
transform: translate(-50%, -50%) rotate(25deg) !important;
}
.firework::after {
transform: translate(-50%, -50%) rotate(-37deg) !important;
}
Kết quả:

Chúc các bạn thành công!
Nguồn tin: Quantrimang.com
Ý kiến bạn đọc
Những tin mới hơn
Những tin cũ hơn
Test nguồn kiến thức agent trong Copilot Studio
Prompt tạo ảnh storyboard gắn với kiến thức bài học
Prompt AI tạo ảnh phong cách đất sét Claymation cực dễ thương
3 điều sẽ thay đổi cách bạn sử dụng Claude mãi mãi
Chỉnh sửa, xem hoặc xóa nguồn kiến thức cho agent trong Copilot Studio
TOP công cụ AI tạo tài liệu tốt nhất
8 trường hợp sử dụng và ví dụ AI agent trong môi trường làm việc
Hướng dẫn tạo game kéo thả Đoàn tàu tri thức
[Video] Cách tạo phiếu học tập ghép nối học số đếm
4 công cụ tìm kiếm AI tốt nhất năm 2026
10 câu lệnh tạo video kể chuyện Facebook cuốn hút
Claude Artifacts là gì? Hướng dẫn sử dụng từ A đến Z
Cách tạo Rubric đánh giá học sinh bằng AI trên Canva
Cách tạo câu hỏi trắc nghiệm trên website diemdanh
TOP công cụ AI phân tích dữ liệu mạng xã hội tốt nhất
Chào ngày mới thứ 6, lời chúc thứ 6 vui vẻ
10 prompt ChatGPT tóm tắt sách giúp hiểu nhanh và nhớ lâu
TOP những trợ lý email AI tốt nhất
Claude Sonnet 5 có gì mới?
Hướng dẫn tạo ảnh AI từ thanh địa chỉ trên Chrome