Tôi có nên sử dụng PostCSS không?
đăngCSS. Chuyển đổi CSS bằng các plugin JS. PostCSS là một công cụ để chuyển đổi CSS bằng các plugin JS. Các plugin này có thể hỗ trợ các biến và mixin, dịch mã cú pháp CSS trong tương lai, hình ảnh nội tuyến, v.v.; . Cú pháp tuyệt vời Style Sheets. Sass là một phần mở rộng của CSS3, thêm các quy tắc lồng nhau, biến, mixin, kế thừa bộ chọn, v.v. Nó được dịch sang CSS tiêu chuẩn, được định dạng tốt bằng cách sử dụng công cụ dòng lệnh hoặc plugin khung web Show
PostCSS và Sass có thể được phân loại là các công cụ "Tiền xử lý CSS/Tiện ích mở rộng" ""Babel" của CSS" là lý do chính khiến các nhà phát triển coi PostCSS hơn các đối thủ cạnh tranh, trong khi "Các biến" được coi là yếu tố chính trong việc chọn Sass PostCSS và Sass đều là công cụ mã nguồn mở. PostCSS với 21 nghìn sao GitHub và 1. 15K fork trên GitHub dường như phổ biến hơn Sass với 12K sao GitHub và 1. 93 nghìn nhánh GitHub Theo cộng đồng StackShare, Sass được chấp thuận rộng rãi hơn, được đề cập trong 2082 ngăn xếp công ty & 1445 ngăn xếp nhà phát triển; Bộ tiền xử lý CSS phổ biến, nhưng chúng có một số nhược điểm. Trong phần giới thiệu về PostCSS này, chúng ta sẽ khám phá những ưu điểm của PostCSS, cách thức hoạt động của nó và phạm vi mở rộng của các plugin của nó có thể đạt được những gì Giá trị và hạn chế của tiền xử lýHầu hết các nhà phát triển CSS đều quen thuộc với bộ tiền xử lý. Các công cụ bao gồm Sass, Less và Stylus đã giới thiệu các khái niệm như phân phần tệp, lồng nhau, biến và mixin. Một số tính năng đang dần xuất hiện trong CSS gốc, nhưng bộ tiền xử lý vẫn hữu ích để quản lý các cơ sở mã lớn và duy trì tính nhất quán về phong cách và mã hóa Có thể khó tưởng tượng cuộc sống mà không có bộ tiền xử lý CSS, nhưng có những nhược điểm
Những lợi ích nhiều hơn những rủi ro này, nhưng có một giải pháp thay thế… PostCSS là gì?PostCSS không phải là bộ tiền xử lý (mặc dù nó có thể hoạt động giống như vậy). Đó là một nút. js lấy CSS hợp lệ và nâng cao nó. Ngay cả những người sử dụng Sass, Less hoặc Stylus cũng thường chạy một bước PostCSS sau quá trình biên dịch CSS ban đầu. Bạn có thể đã gặp plugin PostCSS Autoprefixer tự động thêm tiền tố nhà cung cấp 3, 4 và ________0____5 vào các thuộc tính CSS yêu cầu chúngVề bản thân, PostCSS không làm gì cả. Đó là một trình phân tích cú pháp mã hóa mã CSS để tạo một cây cú pháp trừu tượng. Plugin có thể xử lý cây này và cập nhật các thuộc tính tương ứng. Khi tất cả các plugin đã hoàn thành công việc của chúng, PostCSS sẽ định dạng lại mọi thứ thành một chuỗi và xuất ra tệp CSS Khoảng 350 plugin có sẵn và hầu hết thực hiện một tác vụ đơn lẻ như khai báo nội tuyến 6, đơn giản hóa các hàm 7, xử lý nội dung hình ảnh, linting cú pháp, rút gọn, v.v. Tìm kiếm plugin thân thiện với người dùng hơn có sẵn tại danh mục plugin PostCSSCác lợi ích của PostCSS bao gồm
Cài đặt PostCSSPostCSS yêu cầu Nút. js, nhưng hướng dẫn này trình bày cách cài đặt và chạy PostCSS từ bất kỳ thư mục nào — ngay cả những thư mục không phải là Node. dự án js. Bạn cũng có thể sử dụng PostCSS từ , nhưng chúng tôi sẽ sử dụng dòng lệnh Cài đặt PostCSS trên toàn cầu trên hệ thống của bạn bằng cách chạy như sau
Đảm bảo nó hoạt động bằng cách nhập cái này
Cài đặt plugin PostCSS đầu tiên của bạnBạn sẽ cần ít nhất một plugin để làm bất cứ điều gì thiết thực. Plugin nhập PostCSS là một tùy chọn tốt giúp nội tuyến tất cả các khai báo 6 và hợp nhất CSS của bạn thành một tệp duy nhất. Cài đặt nó trên toàn cầu như vậy
Để kiểm tra plugin này, hãy mở hoặc tạo một thư mục dự án mới, chẳng hạn như 5, sau đó tạo thư mục con 6 cho các tệp nguồn của bạn. Tạo một tệp 7 để tải tất cả các phần________số 8_______Sau đó, tạo một tệp 8 trong cùng một thư mục
Thực hiện theo điều này với một tệp 9
Chạy PostCSS từ thư mục gốc của dự án bằng cách chuyển tệp CSS đầu vào, danh sách plugin tới 0 và tên tệp 1
Nếu bạn không có bất kỳ lỗi nào, đoạn mã sau sẽ được xuất ra tệp 2 mới trong thư mục gốc của dự án
Lưu ý rằng PostCSS có thể xuất các tệp CSS ở bất kỳ đâu, nhưng thư mục đầu ra phải tồn tại; Kích hoạt và vô hiệu hóa bản đồ nguồnBản đồ nguồn nội tuyến được xuất theo mặc định. Khi tệp CSS đã biên dịch được sử dụng trong trang HTML, việc kiểm tra tệp đó trong các công cụ dành cho nhà phát triển của trình duyệt sẽ hiển thị tệp và dòng 6 gốc. Ví dụ: xem kiểu 4 sẽ tô sáng dòng 2 của 5 thay vì dòng 8 của
Bạn có thể tạo bản đồ nguồn bên ngoài bằng cách thêm công tắc 7 (hoặc 8) vào lệnh 9. Có rất ít lợi ích ngoài việc tệp CSS sạch hơn và trình duyệt không cần tải bản đồ nguồn trừ khi các công cụ dành cho nhà phát triển được mởBạn có thể xóa bản đồ nguồn bằng 0. Luôn sử dụng tùy chọn này khi xuất tệp CSS để triển khai sản xuấtCài đặt và sử dụng Plugin AutoPrefixerPlugin Autoprefixer thường là lần gặp đầu tiên của nhà phát triển với PostCSS. Nó thêm tiền tố của nhà cung cấp theo cách sử dụng trình duyệt và các quy tắc được xác định tại caniuse. com. Tiền tố của nhà cung cấp ít được sử dụng hơn trong các trình duyệt hiện đại ẩn chức năng thử nghiệm đằng sau các cờ. Tuy nhiên, vẫn có những thuộc tính như 1 yêu cầu tiền tố 2, 3 và 4Cài đặt plugin trên toàn cầu với cái này
Sau đó, tham chiếu nó như một tùy chọn 0 khác trên lệnh 9 của bạn
Kiểm tra khai báo 7 từ dòng 11 của 2 để xem các thuộc tính có tiền tố nhà cung cấp 0AutoPrefixer sử dụng mô-đun danh sách trình duyệt để xác định tiền tố trình duyệt nào cần thêm. mặc định là
Bạn có thể thay đổi các giá trị mặc định này bằng cách tạo tệp 3. Ví dụ 1Hoặc bạn có thể thêm một mảng 4 vào 5 trong một Nút. dự án js. Ví dụ 2Nhắm mục tiêu các trình duyệt có thị phần từ 2% trở lên chỉ yêu cầu tiền tố 2 trong Safari 3Giảm thiểu CSS với cssnanocssnano thu nhỏ CSS bằng cách loại bỏ khoảng trắng, nhận xét và các ký tự không cần thiết khác. Kết quả sẽ khác nhau, nhưng bạn có thể mong đợi giảm 30% tệp mà bạn có thể triển khai cho các máy chủ sản xuất để có hiệu suất trang web tốt hơn Cài đặt cssnano trên toàn cầu 4Sau đó thêm nó vào lệnh 9 của bạn. Chúng tôi cũng sẽ bao gồm 0 để tắt bản đồ nguồn 5Điều này làm giảm tệp CSS xuống còn 97 ký tự 6Tự động xây dựng khi tệp nguồn thay đổiTùy chọn PostCSS 9 tự động tạo tệp CSS của bạn khi bất kỳ tệp nguồn nào thay đổi. Bạn cũng có thể muốn thêm công tắc 0 báo cáo khi quá trình xây dựng diễn ra 7Thiết bị đầu cuối của bạn sẽ hiển thị 1. Thực hiện thay đổi đối với bất kỳ tệp nào và 2 được xây dựng lại. PostCSS cũng sẽ báo cáo bất kỳ vấn đề nào như lỗi cú phápĐể kết thúc, nhấn Ctrl. Cmd + C trong thiết bị đầu cuối Tạo tệp cấu hình PostCSSLệnh 9 sẽ trở nên dài và rườm rà khi bạn thêm các plugin và tùy chọn khác. Bạn có thể tạo một tệp cấu hình JavaScript xác định tất cả các tùy chọn và có thể xác định một cách hợp lý liệu nó đang chạy trong môi trường phát triển hay sản xuấtTạo một tệp cấu hình có tên 4 trong thư mục gốc của thư mục dự án của bạn. Aso lưu ý những điều sau đây
Thêm đoạn mã sau vào 4 8PostCSS chuyển một đối tượng 1 chứa các tùy chọn dòng lệnh. Ví dụ 9Mô-đun phải trả về một đối tượng có thuộc tính tùy chọn
Đoạn mã trên phát hiện xem lệnh 9 có tùy chọn 6 hay không. Đây là lối tắt để đặt biến môi trường 7. Để biên dịch CSS ở chế độ phát triển, hãy chạy 9 với 9 và, tùy ý, đặt 0. Điều này tạo ra một bản đồ nguồn nội tuyến và không thu nhỏ đầu ra 0Để chạy trong chế độ sản xuất và biên dịch CSS được rút gọn mà không cần bản đồ nguồn, hãy sử dụng cái này 1Lý tưởng nhất là bạn có thể chạy chúng dưới dạng tập lệnh đầu cuối hoặc 1 để giảm thêm nỗ lực nhập liệuTiến độ PostCSSBây giờ bạn đã biết những kiến thức cơ bản về PostCSS. Tăng cường chức năng là vấn đề thêm và định cấu hình các plugin khác. Hãy đầu tư một chút thời gian và bạn sẽ sớm có một quy trình làm việc mà bạn có thể điều chỉnh cho bất kỳ dự án web nào Hướng dẫn về cách sử dụng PostCSS làm giải pháp thay thế có thể định cấu hình cho Sass cung cấp thêm các ví dụ cấu hình và tùy chọn plugin Liên kết khác
Chia sẻ bài viết nàyCraig Buckler Craig là một nhà tư vấn web tự do ở Vương quốc Anh, người đã xây dựng trang đầu tiên của mình cho IE2. 0 vào năm 1995. Kể từ thời điểm đó, anh ấy đã ủng hộ các tiêu chuẩn, khả năng truy cập và các kỹ thuật HTML5 thực hành tốt nhất. Anh ấy đã tạo các thông số kỹ thuật doanh nghiệp, trang web và ứng dụng trực tuyến cho các công ty và tổ chức bao gồm Nghị viện Vương quốc Anh, Nghị viện Châu Âu, Bộ Năng lượng & Biến đổi Khí hậu, Microsoft, v.v. Anh ấy đã viết hơn 1.000 bài báo cho SitePoint và bạn có thể tìm thấy anh ấy @craigbuckler PostCSS có cần thiết không?Không, bạn không cần postcss-loader trong webpack để sử dụng SASS . sass-loader sẽ một mình làm công việc. Mặc dù vậy, cần phải cài đặt node-sass.
PostCSS có còn được sử dụng không?Có thể bạn đã và đang sử dụng PostCSS mà không biết . Nó được sử dụng trong plugin Autoprefixer phổ biến được sử dụng để tự động thêm tiền tố của nhà cung cấp vào các thuộc tính CSS yêu cầu chúng. PostCSS cũng được sử dụng bởi các công nghệ khác như Vite và Next.
Tôi nên sử dụng PostCSS hay Sass?Đó là điểm khác biệt lớn nhất giữa Sass và PostCSS. Sass đi kèm với rất nhiều chức năng sẵn có, ngay cả khi bạn không cần một số chức năng đó. PostCSS cho phép bạn chọn chức năng nào bạn muốn thêm (và họ có một lựa chọn khá tuyệt vời về các plugin được tạo độc lập).
Tôi có thể sử dụng PostCSS với SCSS không?Xin lưu ý rằng Không nên sử dụng PostCSS cùng với SCSS trong một quy trình quy trình làm việc vì điều này gần như không đạt được mục đích của nó. Đó là SCSS sang CSS hoặc PostCSS sang CSS. |