찾다
웹 프론트엔드프런트엔드 Q&Anodejs 템플릿 엔진이란 무엇입니까?

nodejs 템플릿 엔진이란 무엇입니까?

Nov 23, 2021 pm 02:20 PM
nodejs템플릿 엔진

nodejs 템플릿 엔진은 템플릿 파일을 사용하여 HTML 파일을 동적으로 생성할 수 있으며, 특정 규칙에 따라 애플리케이션의 데이터를 HTML 파일에 통합할 수 있습니다. 공통 노드 템플릿 엔진에는 Mustache, Dust.js, doT, Jade, EJS, swig 등이 포함됩니다.

nodejs 템플릿 엔진이란 무엇입니까?

이 튜토리얼의 운영 환경: windows7 시스템, nodejs 버전 12.19.0, DELL G3 컴퓨터.

템플릿 엔진 소개

웹 애플리케이션에서 프론트엔드와 백엔드를 분리하지 않고 서버사이드 코드만 사용하여 클라이언트사이드 HTML 코드를 작성한다면 작업량이 많이 발생하게 되고, 작성된 코드는 읽고 유지하기가 더 어렵습니다. 클라이언트의 정적 HTML 파일만 사용하는 경우 백엔드 논리를 클라이언트의 HTML 코드에 통합하기가 더 어려워집니다.

유지 관리를 용이하게 하고, 백엔드 로직을 프런트엔드 HTML 코드에 더 효과적으로 통합하고, 유지 관리를 용이하게 하기 위해 많은 타사 개발자가 다양한 Nodejs 템플릿 엔진을 개발했습니다.

그렇다면 템플릿 엔진이란 무엇인지 따로 이해할 수 있을까요?

템플릿: 틀(구조물). 데이터를 설정하고 다양한 데이터를 기반으로 다양한 로직을 구현하려면

엔진: 프로세서(컴파일, 실행), 최종적으로 HTML 코드 렌더링

그러므로 템플릿 엔진을 함께 이해해 봅시다. 템플릿 파일을 사용하여 HTML 파일을 동적으로 생성합니다. , 생성 시 특정 규칙에 따라 애플리케이션의 데이터를 HTML 파일에 통합할 수 있습니다. 배경 JSP 언어와 유사합니다.

간단히 말하면 템플릿 엔진은 렌더링 템플릿입니다.

nodejs 템플릿 엔진 요약 및 비교

Mustache

공식 웹사이트: http://mustache.github.io/

Mustache는 로직으로 알려진 매우 간단하고 사용하기 쉬운 템플릿 엔진입니다. -무료 템플릿 엔진. HTML, 구성 파일, 소스 코드 및 기타 시나리오에서 사용할 수 있습니다.

로직이 없는 템플릿 엔진이라고 불리는 이유는 if 문, else 조건, for 루프 및 기타 구조가 없기 때문입니다. 태그만 있으면 태그를 값으로 대체하고 값은 해시일 수도 있고 개체일 수도 있습니다. 그렇게 간단합니다.

Mustache 템플릿에는 Mustache(1)와 Mustache(5)의 두 가지 정의가 있습니다.

Mustache는 Ruby, JavaScript, Python, Erlang, node.js, PHP, Perl, Perl6, Objective-C, Java와 같은 주류 프로그래밍 언어를 지원합니다. , 안드로이드, C++, Go, Lua 등

Mustache는 TextMate, Vim, Emacs, Coda, Atom 등과도 잘 통합됩니다.

콧수염(1) 설명서:
콧수염(5) 설명서:

Mustache (1)은 ctemplate에서 영감을 얻었으며 첫 번째 버전은 2009년 말에 출시되었습니다. 템플릿 엔진의 첫 번째 버전은 Ruby로 구현되었으며 YAML 템플릿 텍스트를 실행했습니다. 채택된 주요 원칙은 다음과 같습니다. 첫째, "논리 없음"을 강조하고, 명시적인 제어 흐름 문이 없으며, 모든 제어가 데이터에 의해 구동됩니다. 둘째, "논리와 표현의 분리"를 강조하고, 애플리케이션 논리를 템플릿에 포함하는 것이 불가능합니다.

Handlebars

공식 웹사이트:

Handlebars.js는 Chris Wanstrath가 만든 Mustache 템플릿 언어의 확장입니다. Handlebars.js와 Mustache는 모두 뷰와 코드를 분리된 상태로 유지하는 논리 없는 템플릿 언어입니다.

일반적으로 Handlebars.js 템플릿의 구문은 Mustache 템플릿의 상위 집합입니다.

기본 구문은 Mustache의 도움말 페이지를 참조하세요:

핸들바를 사용하면 템플릿을 미리 컴파일하고 JavaScript 코드에 포함할 수 있어 시작 시간이 더 빨라집니다. 짧은.

Handlebars가 Mustache와 호환되지 않는 몇 가지 이유:

* 컴파일 타임에 이 기능을 활성화하기 위해 compat 플래그를 설정해야 하는 경우를 제외하고 Handlebars는 기본적으로 재귀 검색을 수행하지 않습니다. 사용자는 이 플래그를 활성화하면 성능 비용이 발생한다는 점을 알고 있어야 합니다.

* 옵션인 콧수염 스타일 람다는 지원되지 않습니다.

* 대체 구분 기호를 지원하지 않습니다.

Dust.js

공식 웹사이트:

Dust는 ctemplate 언어 스타일을 상속하고 디자인된 Javascript 템플릿 엔진입니다. 서버와 브라우저에서 비동기적으로 실행됩니다.

다른 템플릿 엔진과 비교했을 때 Dust는 비논리적이지 않고 단지 논리력이 덜할 뿐입니다.

*Dust 템플릿에는 임의의 Javascript를 작성할 수 없습니다. 그러나 비교, 보다 작음/보다 큼, 존재/부재와 같은 기본 논리 연산자는 여전히 있습니다. 이는 템플릿 가독성과 데이터 제어 간의 균형을 유지합니다.

* Dust는 논리를 데이터 모델로 이동하도록 권장합니다. 모델에서 함수를 생성한 다음 템플릿에서 호출할 수 있으므로 로직을 복잡하게 하지 않고도 템플릿이 렌더링되는 방식을 완벽하게 제어할 수 있습니다.

* 비동기식 템플릿 로드, 렌더링 및 스트리밍. 따라서 템플릿을 미리 로드할 필요가 없습니다.

* 부분 포함 및 동적 템플릿 블록을 지원하는 구성 가능한 템플릿, 템플릿을 함께 결합하여 레이아웃을 수동으로 구성할 수 있습니다.

* HTML에 안전하고 형식에 독립적입니다. Dust는 데이터를 안전하게 이스케이프하여 크로스 사이트 스크립팅 공격을 방지합니다.

*고성능. 성능과 기능 사이의 균형을 유지하세요. Mustache만큼 빠르지는 않지만 비동기식 특성으로 인해 대규모 템플릿을 더 빠르게 렌더링할 수 있습니다.

* Dust는 JavaScript에서 작동합니다.

Underscore.js

공식 웹사이트:

Underscore는 내장 객체를 확장하지 않고도 일련의 유용한 기능적 프로그래밍 도우미를 제공하는 JavaScript 라이브러리입니다.

Underscore는 맵, 필터, 호출은 물론 함수 바인딩, JavaScript 템플릿, 빠른 인덱스 생성, 심층 동등성 테스트 등과 같은 기능을 지원하는 100개 이상의 함수를 제공합니다.

doT

공식 웹사이트:

doT는 사용하기 가장 쉬운 템플릿 엔진은 아니지만 다음 요구 사항을 충족합니다.

* 템플릿 엔진이 클라이언트에 있음

* 템플릿에 대규모 로직이 필요하고 애플리케이션을 빠르게 실행하려는 경우

* 미리 컴파일된 템플릿이 필요한 경우

Jade

공식 웹사이트 :

이 템플릿 엔진을 사용하면 코드 작성이 줄어들고 개발이 쉬워집니다. 다만 파일을 먼저 HTML로 변환한 후 Jade로 변환해야 하기 때문에 Node.js 환경에서 사용하는 것이 시간이 더 많이 걸립니다.

EJS

공식 웹사이트:

EJS는 Observes와의 실시간 바인딩 사용을 제공하는 CanJS의 기본 템플릿 언어입니다. EJS는 사용하기 매우 쉽습니다. 템플릿에 원하는 HTML과 동적 동작을 나타내는 일부 매직 태그를 작성하기만 하면 됩니다. JES는 차단 기능을 지원하지 않습니다.

swig

Swig에는 추상적인 HTML 구문이 없지만 Swig를 사용하여 Angular.js의 구문을 채우고 블록 기능을 지원할 수 있습니다.

노드 관련 지식을 더 보려면 nodejs 튜토리얼을 방문하세요! !

위 내용은 nodejs 템플릿 엔진이란 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
React : 현대 프론트 엔드 개발의 기초React : 현대 프론트 엔드 개발의 기초Apr 19, 2025 am 12:23 AM

React는 현대적인 프론트 엔드 애플리케이션을 구축하기위한 JavaScript 라이브러리입니다. 1. 구성 요소 및 가상 DOM을 사용하여 성능을 최적화합니다. 2. 구성 요소는 JSX를 사용하여 데이터를 관리하기 위해 정의, 상태 및 속성을 정의합니다. 3. 고리는 수명주기 관리를 단순화합니다. 4. ContextApi를 사용하여 글로벌 상태를 관리하십시오. 5. 일반적인 오류는 디버깅 상태 업데이트 및 수명주기가 필요합니다. 6. 최적화 기술에는 메모 화, 코드 분할 및 가상 스크롤이 포함됩니다.

React의 미래 : 웹 개발의 트렌드와 혁신React의 미래 : 웹 개발의 트렌드와 혁신Apr 19, 2025 am 12:22 AM

React의 미래는 궁극적 인 구성 요소 개발, 성능 최적화 및 다른 기술 스택과의 깊은 통합에 중점을 둘 것입니다. 1) RECT는 구성 요소의 생성 및 관리를 더욱 단순화하고 궁극적 인 구성 요소 개발을 촉진합니다. 2) 성능 최적화는 특히 대규모 응용 프로그램에서 초점이됩니다. 3) React는 개발 경험을 향상시키기 위해 GraphQL 및 TypeScript와 같은 기술과 깊이 통합 될 것입니다.

React : UI 구성 요소 구축을위한 강력한 도구React : UI 구성 요소 구축을위한 강력한 도구Apr 19, 2025 am 12:22 AM

React는 사용자 인터페이스를 구축하기위한 JavaScript 라이브러리입니다. 핵심 아이디어는 구성 요소화를 통해 UI를 구축하는 것입니다. 1. 구성 요소는 UI 논리 및 스타일을 캡슐화하는 반응의 기본 단위입니다. 2. 가상 DOM 및 상태 관리는 구성 요소 작업의 핵심이며 State는 SetState를 통해 업데이트됩니다. 3. 수명주기에는 마운트, 업데이트 및 제거의 세 단계가 포함됩니다. 성능을 합리적으로 사용하여 최적화 할 수 있습니다. 4. usestate 및 contextapi를 사용하여 상태를 관리하고 구성 요소 재사용 성 및 글로벌 상태 관리를 개선하십시오. 5. 일반적인 오류에는 부적절한 상태 업데이트 및 성능 문제가 포함되며, 이는 ReactDevTools를 통해 디버깅 할 수 있습니다. 6. 성능 최적화 제안에는 메모 사용, 불필요한 재 렌더링 방지 및 사용이 포함됩니다.

HTML과의 반응 사용 : 구성 요소 및 데이터 렌더링HTML과의 반응 사용 : 구성 요소 및 데이터 렌더링Apr 19, 2025 am 12:19 AM

JSX 구문 사용 : JSX 구문을 사용하여 JSX 구조를 사용하여 HTML 구조를 JavaScript 코드에 포함시키고 컴파일 후 DOM을 작동시킵니다. 구성 요소는 HTML과 결합됩니다. React 구성 요소는 소품을 통해 데이터를 전달하고 HTML 컨텐츠를 동적으로 생성합니다. 데이터 흐름 관리 : React의 데이터 흐름은 일방 통행이며, 부모 구성 요소에서 자식 구성 요소로 전달되어 이름을 인사말로 전달하는 앱 구성 요소와 같이 데이터 흐름을 제어 할 수 있도록합니다. 기본 사용 예 :지도 함수를 사용하여 목록을 렌더링하려면 과일 목록 렌더링과 같은 주요 속성을 추가해야합니다. 고급 사용 예 : Usestate 후크를 사용하여 상태를 관리하고 역학을 구현합니다.

React의 목적 : 단일 페이지 응용 프로그램 구축 (SPA)React의 목적 : 단일 페이지 응용 프로그램 구축 (SPA)Apr 19, 2025 am 12:06 AM

React는 사용자 인터페이스를 구축하는 효율적이고 유연한 방법을 제공하기 때문에 단일 페이지 응용 프로그램 (SPA)을 구축하는 데 선호되는 도구입니다. 1) 구성 요소 개발 : 복잡한 UI를 독립적이고 재사용 가능한 부품으로 분할하여 유지 가능성과 재사용 성을 향상시킵니다. 2) 가상 DOM : 가상 DOM과 실제 DOM의 차이를 비교하여 렌더링 성능을 최적화합니다. 3) 상태 관리 : 데이터 일관성 및 예측 가능성을 보장하기 위해 상태 및 속성을 통한 데이터 흐름을 관리합니다.

React : 웹 개발을위한 JavaScript 라이브러리의 힘React : 웹 개발을위한 JavaScript 라이브러리의 힘Apr 18, 2025 am 12:25 AM

React는 Meta가 사용자 인터페이스를 구축하기 위해 개발 한 JavaScript 라이브러리이며 핵심은 구성 요소 개발 및 가상 DOM 기술입니다. 1. 구성 요소 및 상태 관리 : React는 구성 요소 (기능 또는 클래스) 및 후크 (예 : usestate)를 통해 상태를 관리하여 코드 재사용 및 유지 보수를 개선합니다. 2. 가상 DOM 및 성능 최적화 : 가상 DOM을 통해 실제 DOM을 효율적으로 업데이트하여 성능을 향상시킵니다. 3. 수명주기 및 후크 : 후크 (예 : 사용률) 기능 구성 요소가 수명주기를 관리하고 부작용 작업을 수행 할 수 있도록합니다. 4. 사용 예 : 기본 Helloworld 구성 요소에서 고급 글로벌 주 관리 (Usecontext 및

React의 생태계 : 라이브러리, 도구 및 모범 사례React의 생태계 : 라이브러리, 도구 및 모범 사례Apr 18, 2025 am 12:23 AM

React Ecosystem에는 주정부 관리 라이브러리 (예 : Redux), 라우팅 라이브러리 (예 : Reactrouter), UI 구성 요소 라이브러리 (예 : 재료 -UI), 테스트 도구 (예 : Jest) 및 Webpack과 같은 빌드 도구 (예 : Webpack)가 포함됩니다. 이러한 도구는 개발자가 애플리케이션을 효율적으로 개발하고 유지하고 코드 품질 및 개발 효율성을 향상시킬 수 있도록 함께 작동합니다.

React and Frontend Development : 포괄적 인 개요React and Frontend Development : 포괄적 인 개요Apr 18, 2025 am 12:23 AM

React는 사용자 인터페이스를 구축하기 위해 Facebook에서 개발 한 JavaScript 라이브러리입니다. 1. 구성 요소 및 가상 DOM 기술을 채택하여 UI 개발의 효율성과 성능을 향상시킵니다. 2. RECT의 핵심 개념에는 구성 요소화, 상태 관리 (예 : usestate 및 useeffect) 및 가상 DOM의 작동 원리가 포함됩니다. 3. 실제 응용 분야에서 React는 기본 구성 요소 렌더링에서 고급 비동기 데이터 처리에 이르기까지 지원됩니다. 4. 주요 속성 추가 또는 잘못된 상태 업데이트를 잊어 버린 것과 같은 일반적인 오류는 ReactDevTools 및 Logs를 통해 디버깅 할 수 있습니다. 5. 성능 최적화 및 모범 사례에는 React.Memo, 코드 세분화 및 코드를 읽기 쉽게 유지하고 신뢰성을 유지하는 것이 포함됩니다.

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

뜨거운 도구

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

Dreamweaver Mac版

Dreamweaver Mac版

시각적 웹 개발 도구

Atom Editor Mac 버전 다운로드

Atom Editor Mac 버전 다운로드

가장 인기 있는 오픈 소스 편집기

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

MinGW - Windows용 미니멀리스트 GNU

MinGW - Windows용 미니멀리스트 GNU

이 프로젝트는 osdn.net/projects/mingw로 마이그레이션되는 중입니다. 계속해서 그곳에서 우리를 팔로우할 수 있습니다. MinGW: GCC(GNU Compiler Collection)의 기본 Windows 포트로, 기본 Windows 애플리케이션을 구축하기 위한 무료 배포 가능 가져오기 라이브러리 및 헤더 파일로 C99 기능을 지원하는 MSVC 런타임에 대한 확장이 포함되어 있습니다. 모든 MinGW 소프트웨어는 64비트 Windows 플랫폼에서 실행될 수 있습니다.