Cẩm nang NQDEV
HomeCheat SheetsContact
Công nghệ
Công nghệ
  • Introduction
  • Developer Roadmaps
    • Developer Roadmaps: Mô tả chi tiết
    • Roadmaps: ASP.NET Core Developer
    • Bảng phân loại cấp độ nhà phát triển .NET
    • ClearPath cho Team .NET Core
  • DotNET
    • ASP.NET Core
      • Hướng dẫn sử dụng tệp .http trong Visual Studio 2022 để thực hiện HTTP Requests
    • Message Queue
      • ZeroMQ
        • Xây dựng ZeroMQ Server trong dotNET 8 với CSharp
    • Playwright
      • Playwright: Tự Động Hóa Trình Duyệt Hiệu Quả
    • Optimize
      • Optimize - Một số cách tối ưu code và performance CSharp
    • Dev Blogs
      • Versions of .NET
        • Cập nhật từ .NET 9 lên .NET 10: Những thay đổi quan trọng
      • ASP.NET Core Web API với ASP.NET Core Web API (Native AOT): Bạn nên chọn loại nào?
      • Hướng dẫn xây dựng ứng dụng multi-tenant với .NET Core và MongoDB
      • Kiến Trúc Monolithic và Microservices: Lựa Chọn Phù Hợp Cho Dự Án Của Bạn
  • Design Patterns
    • CQRS Pattern
      • CQRS and MediatR trong .NET Core
    • Microservices
      • Ocelot
  • SQL Server
    • SQL Server Basics
    • SQL Server: DBCC
      • DBCC
      • DBCC SHOW_STATISTICS
      • DBCC SHRINKDATABASE
      • DBCC SHRINKFILE
      • DBCC SQLPERF
      • DBCC FREEPROCCACHE
    • SQL Server Replication
      • Giới thiệu SQL Server Replication
      • Hướng dẫn cấu hình và quản lý SQL Server Replication với Distribution Agent
    • SQL Server: Tập lệnh
      • SQL Server: Tập lệnh để tìm tất cả các giá trị Mặc định với Cột
    • Bảng tạm và sự linh hoạt trong xử lý dữ liệu lớn
    • Các bước để thay đổi nơi lưu trữ tệp log trong SQL Server
    • Các bước di chuyển tệp log trong SQL Server
    • Query Store trong SQL Server - Tổng Quan và Cách Quản Lý Hiệu Quả
    • SQL Server: Error Code
      • SQL Server Error : 14151, Severity: 18. Replication agent
  • Caching
    • Phân tích các phương pháp Caching dữ liệu trong .NET Core và .NET Framework
    • Redis
      • Redis mất dữ liệu khi restart
    • Varnish Cache
      • Hướng Dẫn Cài Đặt Varnish Cache với HAProxy Sử Dụng Docker Compose
  • NodeJS
    • NextJS
      • Hướng dẫn NextJS cho người mới bắt đầu
      • Parallel Routes trong Next.js
      • Hướng dẫn cấu hình Swagger trong NextJS
    • ReactJS
      • Hiểu về hook useRef của React như thế nào cho đúng
      • Tìm hiểu sâu hơn về useEffect từ A-Z
  • OS Linux
    • Tập lệnh Linux hay dùng
    • Centos 7
      • Hướng dẫn cài đặt và cấu hình Centos 7 dành cho người mới bắt đầu
      • Hướng Dẫn Kiểm Tra Các Cổng Đang Mở Trên Hệ Thống CentOS
      • Hướng Dẫn Sử Dụng zip Trên CentOS
      • Hướng dẫn cấu hình iptables để mở tất cả các cổng cho IP private
    • Windows
      • Hướng dẫn quản lý ứng dụng khởi động Windows bằng Registry Editor
  • VMware
    • Cách ảo hóa macOS Sierra trong VMWare Windows 10
    • Tự tin làm chủ mạng lưới: Cẩm nang tính toán địa chỉ IP từ A đến Z
  • Docker
    • Getting Started with Docker
    • Docker HUB
      • nqdev/nginx
  • Templates
    • Tabler Admin Template: Xây dựng Dashboard Quản trị đẹp mắt và dễ dàng
  • Open Source
    • shadcn-ui/ui
    • Kuma UI
    • Midone
  • Ứng dụng
    • Ansible
      • Ansible: Giới thiệu
      • Hướng dẫn chi tiết cài đặt Ansible
    • Apache JMeter
      • Features
        • Hướng dẫn chi tiết về Test Plan trong JMeter
        • Hướng dẫn chi tiết về Thread Group trong JMeter
    • DocFX
      • Những khái niệm cơ bản trong DocFX
      • DocFX - Hướng dẫn cài đặt, cấu hình sử dụng
      • DocFX - Hướng dẫn Markdown
      • DocFX - Hướng dẫn cấu hình file docfx.json
      • DocFX - Hướng dẫn sử dụng và tùy chỉnh Template
    • ETL Tools
      • Công cụ ETL Tools List & Software
      • Airbyte
        • Docker Compose
    • Elasticsearch
      • _reindex
        • Tìm hiểu sâu về API _reindex trong Elasticsearch
        • Hướng dẫn di chuyển dữ liệu trong Elasticsearch sử dụng API _reindex
      • _transform
    • HAProxy
      • HAProxy - Lập trình Lua và tích hợp Redis
    • Localtunnel
      • Hướng dẫn sử dụng Localtunnel để đưa ứng dụng Local lên Internet
    • LoopBack
      • Hướng dẫn cài đặt LoopBack 4 và khởi tạo dự án đầu tiên
    • N8N
      • Hướng dẫn cài đặt n8n bằng docker compose
    • NGINX Plus
      • NGINX: Hiệu suất vượt trội và giải pháp tối ưu cho hệ thống web
      • NGINX: Hướng dẫn chi tiết sử dụng GeoIP2 trên Alpine
      • NGINX: Hướng dẫn sử dụng Lua trên Alpine
      • NGINX: Hướng Dẫn Chi Tiết Cấu Hình Load Balancer
      • NGINX: Hướng Dẫn Sử Dụng Dynamic Modules
      • NGINX: Hướng dẫn Cài đặt và Sử dụng Module njs
      • Tích Hợp NGINX Làm API Gateway với Các Bước Xử Lý Phổ Biến
    • NTP - Secure Timeserver
      • Hướng dẫn cài đặt NTP an toàn với Docker Compose
    • Playwright
      • Playwright: Tự Động Hóa Trình Duyệt Hiệu Quả
    • Wordpress
      • Cách dùng Docker để phát triển ứng dụng Wordpress
  • Tin tức
    • DevSecOps là gì?
    • Giới thiệu bộ công cụ hỗ trợ lập trình từ SmallDev.tools và Code Beautify
    • Giới Thiệu và Hướng Dẫn Về DuckDB
    • Giới thiệu về Các Loại Cơ Sở Dữ Liệu
      • 1. HSQLDB (HyperSQL Database)
    • Hệ thống phân giải tên miền (DNS) và các loại bản ghi
    • Giải thích về Tiền Tố Path Nổi Tiếng – /.well-known
    • Giải mã Hệ thống tạo mã OTP của Google Authenticator
    • Quishing là gì? Hiểu và phòng tránh lừa đảo qua mã QR
  • Hướng dẫn
    • Hướng dẫn chi tiết tạo tài khoản Google bằng email công ty
    • Top 10 ASP .NET Open Source Projects GitHub 2024
    • Free Themes and Templates from Creative Tim
    • Hướng dẫn sử dụng Voler và Mazer Dashboard từ Zuramai
  • So Sánh
    • So Sánh Apache Parquet và CSV: Bảng So Sánh Chi Tiết, Ưu và Nhược Điểm
    • So Sánh Varnish Cache, Memcached và Redis: Ba Công Cụ Caching Phổ Biến trong Tối Ưu Hóa Hiệu Suất
  • Affiliate
    • Tuyển dụng
      • Bộ câu hỏi phỏng vấn T-SQL – Đánh giá ứng viên hiệu quả
    • eSMSvn: Chăm sóc khách hàng hiệu quả với SMS và ZNS
    • eSMS.vn: Giải pháp SMS Marketing hiệu quả cùng các chương trình ưu đãi hấp dẫn
Powered by GitBook
On this page
  • Giới thiệu
  • 1. Template trong DocFX là gì?
  • Các template phổ biến:
  • 2. Template Metadata
  • 3. Cách sử dụng template
  • 3.1. Áp dụng template mặc định
  • 3.2. Áp dụng nhiều template
  • 4. Tùy chỉnh template
  • 4.1. Xuất template mặc định
  • 4.2. Chỉnh sửa template
  • 4.3. Áp dụng template tùy chỉnh
  • 5. Tính năng nâng cao của template
  • 5.1. Hỗ trợ Data Binding
  • 5.2. Tích hợp Metadata
  • 5.3. Chạy Post Processor
  • 6. Mẹo tối ưu hóa khi tùy chỉnh template
  • 7. Kết hợp template với đa ngôn ngữ
  • 8. Tài nguyên tham khảo
  • Kết luận

Was this helpful?

  1. Ứng dụng
  2. DocFX

DocFX - Hướng dẫn sử dụng và tùy chỉnh Template

PreviousDocFX - Hướng dẫn cấu hình file docfx.jsonNextETL Tools

Last updated 5 months ago

Was this helpful?

Giới thiệu

Template trong DocFX là công cụ mạnh mẽ giúp bạn tùy chỉnh giao diện và cách hiển thị tài liệu của mình. DocFX hỗ trợ nhiều template mặc định và cho phép người dùng tùy chỉnh template theo nhu cầu. Trong bài viết này, chúng ta sẽ tìm hiểu cách sử dụng, tùy chỉnh và áp dụng template trong DocFX.


1. Template trong DocFX là gì?

Template là một tập hợp các tệp HTML, CSS, JavaScript, và các tài nguyên khác, xác định cách trình bày nội dung tài liệu. DocFX cung cấp template mặc định và hỗ trợ xuất hoặc tạo template tùy chỉnh.

Các template phổ biến:

  • Default: Template mặc định, dễ sử dụng và phù hợp với hầu hết các dự án.

  • Custom: Template tùy chỉnh do người dùng tự tạo hoặc sửa đổi.


2. Template Metadata

Các mẫu bổ sung có sẵn tại .

Cách dễ nhất để tùy chỉnh giao diện của trang là sử dụng . Dưới đây là danh sách siêu dữ liệu được xác định trước:

Name
Type
Description

_appTitle

string

A string append to every page title.

_appName

string

The name of the site displayed after logo.

_appFooter

string

The footer HTML.

_appLogoPath

string

Path to the app logo.

_appLogoUrl

string

URL for the app logo.

_appFaviconPath

string

Favicon URL path.

_enableSearch

bool

Whether to show the search box.

_noindex

bool

Whether to include in search results

_disableContribution

bool

Whether to show the "Edit this page" button.

_gitContribute

object

Defines the repo and branch property of git links.

_gitUrlPattern

string

URL pattern of git links.

_disableNewTab

bool

Whether to render external link indicator icons and open external links in a new tab.

_disableNavbar

bool

Whether to show the navigation bar.

_disableBreadcrumb

bool

Whether to show the breadcrumb.

_disableToc

bool

Whether to show the TOC.

_disableAffix

bool

Whether to show the right rail.

_disableNextArticle

bool

Whether to show the previous and next article link.

_disableTocFilter

bool

Whether to show the table of content filter box.

_googleAnalyticsTagId

string

Enables Google Analytics web traffic analysis.

_lang

string

Primary language of the page. If unset, the <html> tag will not have lang property.

_layout

string

Determines the layout of the page. Supported values are landing and chromeless.

Name
Type
Description

_appTitle

string

A string append to every page title.

_appName

string

The name of the site displayed after logo.

_appFooter

string

The footer HTML.

_appLogoPath

string

Path to the app logo.

_appLogoUrl

string

URL for the app logo.

_appFaviconPath

string

Favicon URL path.

_enableSearch

bool

Whether to show the search box.

_enableNewTab

bool

Whether to open external links in a new tab.

_noindex

bool

Whether to include in search results

_disableContribution

bool

Whether to show the "Improve this Doc" and "View Source" buttons.

_gitContribute

object

Defines the repo and branch property of git links.

_gitUrlPattern

string

URL pattern of git links.

_disableNavbar

bool

Whether to show the navigation bar.

_disableBreadcrumb

bool

Whether to show the breadcrumb.

_disableToc

bool

Whether to show the TOC.

_disableAffix

bool

Whether to show the right rail.

_googleAnalyticsTagId

string

Enables Google Analytics web traffic analysis.

_lang

string

Primary language of the page. If unset, the <html> tag will not have lang property.


3. Cách sử dụng template

3.1. Áp dụng template mặc định

Trong file docfx.json, bạn có thể chỉ định template cần sử dụng bằng cách thêm cấu hình:

{
  "build": {
    "template": ["default"]
  }
}

3.2. Áp dụng nhiều template

DocFX hỗ trợ áp dụng nhiều template theo thứ tự ưu tiên:

{
  "build": {
    "template": ["custom-template", "default"]
  }
}
  • Nếu không tìm thấy tệp trong custom-template, DocFX sẽ tự động sử dụng tệp từ template default.


4. Tùy chỉnh template

DocFX cho phép bạn tùy chỉnh template để phù hợp với thương hiệu hoặc yêu cầu dự án.

4.1. Xuất template mặc định

Để tùy chỉnh, bạn cần xuất template mặc định và chỉnh sửa:

docfx template export default
  • Template sẽ được xuất vào thư mục templates/default.

4.2. Chỉnh sửa template

Trong thư mục template, bạn có thể chỉnh sửa:

  • HTML: Thay đổi cấu trúc giao diện.

  • CSS: Tùy chỉnh màu sắc, font chữ, và phong cách.

  • JavaScript: Thêm tính năng hoặc tương tác mới.

4.3. Áp dụng template tùy chỉnh

Sau khi chỉnh sửa, áp dụng template bằng cách cấu hình:

templates/
|-- default/
    |-- styles/        # Chứa file CSS
    |-- scripts/       # Chứa file JavaScript
    |-- partials/      # Các thành phần HTML tái sử dụng
    |-- layout.html    # Layout chính của trang
    |-- toc.html       # Giao diện Table of Contents
    |-- ...            # Các tệp khác

Mô tả các thành phần chính:

  • layout.html: Tệp HTML chính quyết định bố cục chung.

  • partials/: Chứa các phần giao diện có thể tái sử dụng, như header, footer.

  • styles/: Tùy chỉnh giao diện bằng CSS.

  • scripts/: Tích hợp các tính năng tương tác bằng JavaScript.


5. Tính năng nâng cao của template

5.1. Hỗ trợ Data Binding

DocFX hỗ trợ Liquid template, cho phép bạn sử dụng các biến và vòng lặp trong tệp HTML:

{{ page.title }}  <!-- Hiển thị tiêu đề trang -->
{% for item in model.items %}
    <a href="{{ item.href }}">{{ item.name }}</a>
{% endfor %}

5.2. Tích hợp Metadata

Bạn có thể sử dụng metadata để tùy chỉnh nội dung hiển thị:

{% if model.metadata.language == "en" %}
    <p>This is an English page</p>
{% else %}
    <p>This is a localized page</p>
{% endif %}

5.3. Chạy Post Processor

Bạn có thể thêm Post Processor để xử lý template sau khi build:

{
  "build": {
    "postProcessors": ["CustomPostProcessor"]
  }
}
  • Post Processor là script tùy chỉnh để sửa đổi output cuối cùng.


6. Mẹo tối ưu hóa khi tùy chỉnh template

  1. Giữ nguyên backup template gốc: Trước khi chỉnh sửa, luôn sao lưu template mặc định để tránh lỗi không mong muốn.

  2. Sử dụng CSS thay vì sửa HTML: Hạn chế chỉnh sửa HTML trực tiếp, sử dụng CSS để giữ tính nhất quán.

  3. Kiểm tra tương thích: Sau khi chỉnh sửa, kiểm tra trên nhiều trình duyệt để đảm bảo giao diện hoạt động tốt.


7. Kết hợp template với đa ngôn ngữ

Nếu dự án hỗ trợ đa ngôn ngữ, bạn có thể tạo các file riêng cho mỗi ngôn ngữ trong template:

  • Tạo các file như layout.vi.html hoặc layout.en.html.

  • Sử dụng cấu hình ngôn ngữ trong docfx.json:

{
  "build": {
    "locales": ["en-us", "vi-vn"]
  }
}

8. Tài nguyên tham khảo

- [Tài liệu chính thức về template DocFX](https://dotnet.github.io/docfx/docs/template.html)
- [Hướng dẫn tùy chỉnh giao diện]()


Kết luận

Template trong DocFX là công cụ mạnh mẽ giúp bạn tạo ra tài liệu chuyên nghiệp và phù hợp với thương hiệu. Với bài viết này, bạn đã nắm được cách sử dụng và tùy chỉnh template để tạo ra các giao diện tài liệu độc đáo.

Nếu bạn có thắc mắc hoặc cần hỗ trợ thêm, hãy để lại bình luận bên dưới. Hãy thử ngay và chia sẻ kết quả của bạn nhé! 😊

Thư viện Mẫu
metadata