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

Giới thiệu Template Engine Pug - Một cách viết HTML mới

0 0 58

Người đăng: Nguyễn Đình Phú Nguyên

Theo Viblo Asia

Đối với hầu hết chúng ta, HTML là bước đầu tiên của chúng ta khi đặt chân vào Web Development. Bình thường chúng ta có thể viết HTML bằng cú pháp truyền thống, nhưng khi chúng ta phát triển, thì các công cụ của chúng ta cũng như vậy. CSS, với các dấu ngoặc , dấu chấm phẩy,... thì cuối cùng đã tạo SASS, nó cho cho phép code chúng ta clean hơn, code nhanh hơn, và còn mang tới rất nhiều chức năng đáng chú ý.

Bây giờ, trong thời đại của các Code Editor, HTML đã được cải tiến. Chúng ta không còn phải lo lắng về việc đóng thẻ hay việc copy/pasting nhưng thẻ trùng lặp. Ví dụ như 1 <ul> có thể được tạo bằng 2 dòng cho dù có bao nhiêu thẻ <li> được chứa trong nó, hay bạn có thể sử dụng những vòng lặp,... Điều này có thể thực hiện được là nhờ một template engine cho Node.js và nó được gọi là Pug (trước đây được gọi là Jade).

Nếu bạn muốn tìm hiểu trước về Pug và các tính năng của nó , thì bạn tìm hiểu tại đây

Cài đặt Pug

Cài đặt Pug dễ dàng như cách sử dụng nó. Theo đúng nghĩa đen, bạn có thể cài đặt và bắt đầu sử dụng pug trong vài phút. Pug giống như các nói Node package khác, có thể cài đặt thông qua các lệnh npm hoặc yarn, cụ thể như sau :

  • Đối với npm:
npm install pug-cli -g
  • Đối với yarn:
yarn global add pug-cli

Để biên dịch một tệp (ví dụ: example.pug thành example.html), chúng ta sử dụng:

pug -P example.pug

Pug là một template engine hoàn chỉnh cho HTML?

Giống như nhiều ngôn ngữ khác, nó cung cấp các cấu trúc điều khiển (nếu, trừ khi, mỗi, trường hợp…),...

Syntax

Tên của các thẻ trong Pug được lấy cảm hứng từ cú pháp CSS. Ngoài ra, cú pháp phụ thuộc vào thụt đầu dòng của nó làm cho nó trở nên cô đọng hơn, dễ đọc hơn và ít gặp vấn đề về việc không có thẻ đóng hơn.

Đây là 1 ví dụ cụ thể:

article#article-1 h2 Class and id .class Class #id Id

Chúng ta sẽ nhận được HTML như sau:

<article id="article-1"> <h2>Class and id</h2> <div class="class">Class</div> <div id="id">Id</div>
</article>

Mixins

Để sử dụng lại các phần code một số nơi mà không cần viết lại cấu trúc hoặc các tham số,thì chúng có các mixin.

Ví dụ về mixin đại diện cho một biểu tượng với văn bản, hình ảnh, liên kết:

mixin textIcon(text, image, url) a(href=url).text-icon figure img(src=image, alt=text + ' icon').icon figcaption.text=text

Việc sử dụng một mixin được thực hiện bằng cách đặt trước tên của nó bằng dấu +. Trong trường hợp của chúng tôi, đó là + textIcon:

.icon-list +textIcon('Chrome', '/images/chrome-logo.png', 'https://www.google.fr/chrome/index.html') +textIcon('Firefox', '/images/firefox-logo.png', 'https://www.mozilla.org/fr/firefox') +textIcon('Edge', '/images/edge-logo.png', 'https://www.microsoft.com/fr-fr/windows/microsoft-edge') +textIcon('Safari', '/images/safari-logo.png', 'https://www.apple.com/fr/safari')

Khi nó được biên dịch qua HTML, nó sẽ trong như thế này:

<div class="icon-list"> <a class="text-icon" href="https://www.google.fr/chrome/index.html"> <figure> <img class="icon" src="/images/chrome-logo.png" alt="Chrome icon" /> <figcaption class="text">Chrome</figcaption> </figure> </a> <a class="text-icon" href="https://www.mozilla.org/fr/firefox"> <figure> <img class="icon" src="/images/firefox-logo.png" alt="Firefox icon" /> <figcaption class="text">Firefox</figcaption> </figure> </a> <a class="text-icon" href="https://www.microsoft.com/fr-fr/windows/microsoft-edge"> <figure> <img class="icon" src="/images/edge-logo.png" alt="Edge icon" /> <figcaption class="text">Edge</figcaption> </figure> </a> <a class="text-icon" href="https://www.apple.com/fr/safari"> <figure> <img class="icon" src="/images/safari-logo.png" alt="Safari icon" /> <figcaption class="text">Safari</figcaption> </figure> </a>
</div>

Loop

Bạn cũng có thể thực hiện các thao tác lặp bằng cú pháp each-in hoặc while. Trong đoạn mã bên dưới, chúng tôi đã lặp qua một mảng để hiển thị danh sách các biến (lưu ý việc sử dụng 'li =' để đánh giá "val" như một biến bên dưới. Giá trị bạn lặp lại cũng có thể được chuyển vào mẫu như một biến!)

ul each val in [1, 2, 3, 4, 5] li= val

Khi đó chúng ta sẽ nhận được mã HTML như sau:

<ul> <li>1</li> <li>2</li> <li>3</li> <li>4</li> <li>5</li>
</ul>

Nếu bạn muốn tìm hiểu sâu hơn, và nhiều hơn tại đây:

  1. https://pugjs.org/api/getting-started.html
  2. https://developer.mozilla.org/en-US/docs/Learn/Server-side/Express_Nodejs/Displaying_data/Template_primer

Bình luận

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

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

Một số quy tắc và name class phổ biến cho Front-end Dev

Trong CSS, các thủ tục setting đóng vai trò to lớn, nhưng bên cạnh đó, cách đặt tên theo các từ đơn sao cho phù hợp cũng quan trọng không kém . Đặt tên rất khó, nhưng cũng rất quan trọng .

0 0 93

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

2021, chúng ta cần tối ưu hóa việc tải hình ảnh trên web như nào?

Rất chào các bạn,. Như các bạn đã biết, trong kỉ nguyên công nghệ, song song với sự sinh ra dày đặc của các trang web mới cũng là sự biến mất của những trang web "lạc hậu" hay hoạt động kém hiệu quả.

0 0 57

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

Tài nguyên nghiên cứu sâu Html

1. Articles and standards. . HTML 5.

0 0 198

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

Tìm hiểu về Event.preventDefault(), Event.stopPropagation() và Event.stopImmediatePropagation()

Chúng ta thương thấy 3 method này và có thể dẫn dến bối rối và nhầm lẫn giữa chúng:. . Event.preventDefault().

0 0 52

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

Vanilla JS Project: Tính tuổi

1. Yêu cầu.

0 0 74

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

Thủ thuật nhỏ để căn chỉnh image với object-fit

Chào các bạn,. Có lẽ trong hành trình code của các bạn thì không ít lần gặp vấn đề méo ảnh do fix cứng cả width, height của ảnh nhỉ? Hoặc kể cả khi bạn set value cho 1 thuộc tính weigth hoặc height còn thuộc tính còn lại để auto thì nhiều lúc ảnh cũng không được hiển thị toàn vẹn cho lắm.

0 0 49