Chủ đề (themes) và chế độ (modes) trong hệ thống thiết kế là hai khái niệm riêng biệt: themes xác định bảng màu và nhận diện thương hiệu, còn modes kiểm soát độ sáng (sáng, tối, tương phản cao) nhằm tăng khả năng truy cập. Tách biệt chúng bằng CSS custom properties và các thuộc tính HTML (data-theme, data-mode) giúp quản lý độc lập, giảm độ phức tạp khi mở rộng. Cách tiếp cận này cho phép dark mode được định nghĩa một lần và áp dụng toàn hệ thống, các themes mới chỉ cần cập nhật màu sắc thương hiệu, đồng thời cải tiến khả năng truy cập sẽ tự động lan tỏa.
Vì sao nên đọc: Lập trình viên nên đọc bài này để hiểu cách tối ưu hóa thiết kế hệ thống bằng cách phân tách chủ đề (theme) và chế độ (mode) để giảm bớt sự phức tạp khi mở rộng ứng dụng và đảm bảo tính linh hoạt, khả năng mở rộng và khả năng tương thích với các tiêu chuẩn thiết kế hiện đại.
Nguồn: https://www.alwaystwisted.com/articles/why-separating-themes-from-modes-transforms-your-design-system.html. 8sync News chỉ tóm tắt và dẫn link; bản quyền nội dung thuộc tác giả và nguồn gốc.

CSS pseudo-classes ngày càng tương đồng với JavaScript event listeners, giúp xử lý trạng thái UI mà không cần viết JS. Bài viết so sánh các pseudo-classes phổ biến (:hover, :focus, :valid...) với sự kiện JavaScript tương ứng, đồng thời giới thiệu spec event-trigger mới (chưa được hỗ trợ) cho phép CSS lắng nghe sự kiện trực tiếp để kích hoạt animation.
Những kiến thức về sự tương đồng giữa các trạng thái CSS và sự kiện JavaScript giúp lập trình viên tối ưu hóa mã, giảm bớt sự phụ thuộc vào JavaScript và khám phá các tính năng tương lai của CSS để làm UI đẹp hơn, nhanh hơn và hiệu suất cao hơn.
Bài viết hướng dẫn tạo hiệu ứng mặt nạ (mask) gradient xuyên tâm hoạt ảnh trên văn bản bằng CSS, sử dụng thuộc tính mask kết hợp repeating-radial-gradient, điều chỉnh tâm gradient quanh một chữ cái cụ thể, và tận dụng @property (CSS Houdini) để làm thuộc tính tùy chỉnh có thể hoạt ảnh. Ngoài ra, bài viết cũng đề cập đến sự tương thích trình duyệt không đồng nhất trên Firefox và Safari, cùng các mẹo điều chỉnh độ dày và khoảng cách sọc thông qua thuộc tính CSS tùy chỉnh.
Lập trình viên nên đọc bài này để khám phá cách tạo hiệu ứng ánh sáng động từ gradient bán kính trên văn bản bằng CSS, giúp nâng cao tính tương tác và thẩm mỹ cho giao diện web mà không cần JavaScript.
ARIA Authoring Practices Guide (APG) không phải hướng dẫn tối ưu cho website mà chỉ minh …

Thư viện Prop For That của Adam Argyle cung cấp các CSS custom properties động, cho phép truy cập vào những thuộc tính CSS thông thường không thể truy xuất như vị trí con trỏ, tốc độ cuộn, trạng thái form hay thời gian hiện tại. Nhà phát triển chỉ cần thêm thuộc tính data vào HTML, sau đó sử dụng trực tiếp các biến CSS này trong stylesheet mà không cần viết JavaScript.
Lập trình viên nên đọc bài này để khám phá cách Prop For That giúp tối ưu hóa giao diện người dùng bằng cách kết nối trực tiếp CSS với dữ liệu động từ HTML mà không cần JavaScript, mở rộng khả năng tùy biến UI một cách đơn giản và hiệu quả.
Kỹ thuật CSS thuần tạo thanh trượt (range slider) dạng lượn sóng bằng phần tử HTML input gốc, sử dụng các tính năng hiện đại như border-shape, Scroll-Driven Animations và @property mà không cần JavaScript hay HTML bổ sung. Chỉ hoạt động trên Chrome, cho phép tùy biến dễ dàng qua CSS variables và có công cụ hỗ trợ tạo đường lượn sóng.
Lập trình viên nên đọc bài này để khám phá cách tạo hiệu ứng slider dải nhập gợn sóng chỉ bằng CSS hiện đại, tiết kiệm thời gian và không cần JavaScript, giúp tối ưu hóa hiệu suất và mở rộng khả năng thiết kế UI cho ứng dụng Chrome.
Bài viết hướng dẫn cách xây dựng một component React đa hình có kiểu (polymorphic) bằng generics TypeScript. Tác giả chỉ ra nhược điểm của cách dùng intersection type thông thường, khám phá cách sử dụng mapped type (hoặc Omit) để buộc TypeScript xử lý generic sau khi suy luận kiểu, từ đó đạt được cách triển khai cho phép props được xác định chặt chẽ dựa trên giá trị của prop as.
Lập trình viên nên đọc bài này để hiểu cách tối ưu hóa và chính xác hóa kiểu dáng cho các thành phần React đa hình với TypeScript, tránh những lỗi nhầm lẫn về kiểu props và giải quyết vấn đề khi kiểu không được hẹp hóa đúng cách.
Bài viết bàn về sự thay đổi trong phương pháp CSS từ các quy ước nghiêm ngặt như BEM, SMACSS, ITCSS sang cách tiếp cận linh hoạt hơn nhờ các tính năng hiện đại như cascade layers, @scope, @container và :where. Tác giả chia sẻ sở thích cá nhân khi viết hoa tên class component (ví dụ: class="Post") để tăng tính rõ ràng, đồng thời nhắc nhở về hạn chế của việc phụ thuộc quá nhiều vào class selectors theo đặc tả CSS Level 1.
Bạn nên đọc bài này để hiểu cách CSS đã thay đổi từ quy tắc cứng nhắc truyền thống sang sự linh hoạt mới mẻ nhờ công nghệ hiện đại, giúp bạn tối ưu hóa cách viết mã CSS hiệu quả hơn mà không cần lo lắng về các quy ước cũ.
CSS Grid Lanes giới thiệu hệ thống layout mới với hai trục căn chỉnh: trục grid (xếp lane) và trục xếp chồng (các item nằm trong lane). Căn chỉnh theo trục grid tương tự CSS Grid tiêu chuẩn (dùng justify-*/align-* cho chiều ngang/dọc), còn căn chỉnh trục xếp chồng (như align-items: stretch) cho phép các item lấp đầy khoảng trống. Tính năng này đang được triển khai trên Chromium và Safari, với hỗ trợ gần hoàn thiện trên Chromium.
Lập trình viên nên đọc bài này để hiểu cách tối ưu hóa bố cục grid với các tính năng mới như align-items trên trục xếp chồng và cách điều khiển align-content cho không gian dư thừa, giúp thiết kế UI đẹp hơn và hiệu suất cao hơn trong các trình duyệt hiện đại.