웹 프론트엔드 JS 튜토리얼 Ghost에서 맞춤형 핸들바 도우미를 만들어보세요!

Ghost에서 맞춤형 핸들바 도우미를 만들어보세요!

Jan 07, 2025 am 12:08 AM

Make Custom Handlebar Helpers in Ghost!

이 글은 Ghost(https://ghost.org/docs/themes/helpers/)에서 제공하는 표준 도우미가 부족하다고 생각하는 많은 개발자와 테마 제작자를 위한 것입니다. Ghost가 제공하는 핸들바를 사용하여 테마의 기능을 확장하는 방법을 찾는 것은 완전히 정상적인 일입니다. 이 글을 게시하고 내 주제에 대한 해결책을 찾기 전에 인터넷 전체를 검색하고 Ghost의 소스 코드를 직접 분석했습니다.

방법 1(핵심코드 수정)

추가 도우미를 사용하여 Ghost의 소스 코드를 확장할 수 있다는 것을 발견했습니다. current/core/frontend/apps에 새 디렉토리를 추가하여 이를 달성했습니다. 나는 테마에서 사용할 수 있는 새로운 도우미를 만들기 시작하기 위해 코드가 매우 간단한 amp라는 기존 "앱"의 예를 사용했습니다. 이러한 기존 앱에서는 헬퍼가 lib/helpers에 등록되어 있으므로 구조가 간단합니다. 프로세스가 끝나면 apps.internal JSON 섹션의 current/core/shared/config/overrides.json에 앱의 디렉터리 이름을 추가해야 합니다.

우리 앱에 있는 index.js 파일의 예시 콘텐츠는 다음과 같습니다.

const path = require('path');

module.exports = {
    activate: function activate(ghost) {
        ghost.helperService.registerDir(path.resolve(__dirname, './lib/helpers'));
    }
};
로그인 후 복사
로그인 후 복사
로그인 후 복사

다음으로 이 앱의 lib 디렉터리에 helpers라는 폴더를 만듭니다. 내부에서 Handlebars 템플릿에서 호출할 도우미의 이름이 될 새 파일을 만듭니다. 예를 들어 이름을 uppercase.js로 지정하겠습니다.

다음은 도우미 인수에 지정된 텍스트의 글자를 대문자로 변환하는 도우미 코드의 예입니다.

const {SafeString, escapeExpression} = require('../../../../services/handlebars');

module.exports = function uppercase(text) {
    return `${text.toUpperCase()}`;
};
로그인 후 복사
로그인 후 복사
로그인 후 복사

current/core/shared/config/overrides.json에 애플리케이션 디렉터리 이름을 추가하는 것을 잊지 마세요. Ghost를 다시 시작하면 모든 것이 준비됩니다.

방법 2(핵심 코드 수정 없음)

최근 이 방법을 개발했는데, 자체 호스팅 Ghost뿐만 아니라 호스팅 제공업체에서 제공하는 Ghost 인스턴스에도 적용할 수 있습니다. 후자의 경우 적절한 아키텍처 계획과 최종 Ghost 인스턴스의 프록시 역할을 할 소형 서버 구입이 필요합니다.

이 방법에서 사용할 아키텍처:
Nginx 서버 ← Node.js 미들웨어 ← Ghost 인스턴스

사용자의 브라우저는 미들웨어의 업스트림이 포함된 Nginx 서버에 요청을 보냅니다. 위치에 관계없이 모든 요청은 미들웨어로 프록시 처리됩니다.

미들웨어는 express-http-proxy(https://github.com/villadora/express-http-proxy) 라이브러리가 추가된 Node.js에서 실행되는 Express 서버로, 작업을 대폭 단순화합니다. Ghost 인스턴스와 통신하도록 프록시를 구성합니다. express-http-proxy 라이브러리에는 "프록시 서버의 응답을 장식"하는 데 사용할 수 있는 userResDecorator 속성이 있습니다. 간단히 말해서 Ghost의 응답을 사용자의 브라우저로 보내기 전에 수정할 수 있습니다.

userResDecorator는 메인 스레드를 차단하지 않도록 비동기식으로 작동합니다. 도우미를 만들 때 비동기 처리 주제로 돌아가겠습니다. 지금은 사용자의 브라우저 요청이 모두 장식될 필요는 없다는 점을 알아야 합니다. 따라서 첫 번째 단계는 Ghost 응답의 콘텐츠 유형 헤더를 확인하는 것입니다. 다음과 같이 수행한 다음 text/html인지 비교하여 사용자에게 반환된 HTML 문서만 장식할 수 있습니다.

const path = require('path');

module.exports = {
    activate: function activate(ghost) {
        ghost.helperService.registerDir(path.resolve(__dirname, './lib/helpers'));
    }
};
로그인 후 복사
로그인 후 복사
로그인 후 복사

이 조건문에서 htmlContent 수정을 시작할 수 있지만 왜 필요한가요? Ghost 테마에서 맞춤 도우미의 기반을 구축하는 것부터 시작하겠습니다!

이번 글에서는 테마의 index.hbs 파일(홈페이지)에 커스텀 헬퍼를 생성해보겠습니다. Handlebars 템플릿의 눈에 보이는 위치에 예제 사용자 지정 도우미를 추가하고 이름을 {{hello_world}}로 지정합니다.

⚠️ 그런 다음 홈페이지의 눈에 띄는 위치에 배치합니다. 하지만 Ghost 페이지를 새로 고치면 어떻게 되는지 확인하세요!

const {SafeString, escapeExpression} = require('../../../../services/handlebars');

module.exports = function uppercase(text) {
    return `${text.toUpperCase()}`;
};
로그인 후 복사
로그인 후 복사
로그인 후 복사

이 변수에는 페이지의 전체 HTML로 Ghost 인스턴스의 응답이 있습니다. 이 응답이 Ghost 인스턴스의 홈페이지라고 상상해 보세요. HTML 콘텐츠에는 일반 텍스트로 표시되는 일반 텍스트 {{hello_world}}도 포함됩니다. 사용자 정의 도우미가 이 형식인 경우 미들웨어에서 Handlebars.js(https://handlebarsjs.com/)를 사용하여 컴파일할 수 있습니다. 먼저 패키지 관리자를 통해 라이브러리를 설치해야 합니다(예: npm: npm install handlerbars). 그리고 이를 코드에 추가합니다: const handlerbars = require("handlebars");.

// Where 'proxyRes' is your proxy response inside 'userResDecorator'
const contentType = proxyRes.headers['content-type'] || '';
if (!contentType.includes('text/html')) {
    // Return original content if response is not 'text/html'
    return proxyResData;
}

let htmlContent = proxyResData.toString('utf8');
// Do something with 'htmlContent' and return
return htmlContent;
로그인 후 복사

와! 이제 Handlebars.js를 사용하여 HTML을 컴파일하고 렌더링했지만 아직 완료되지 않았습니다. 아직 맞춤 도우미 {{hello_world}}를 등록해야 합니다. 가급적이면 Handlebars.js를 초기화한 후 다음 코드를 추가하세요.

{{!< default}}
<div>



<p>After refreshing, I get an error message from Ghost because the {{hello_world}} helper doesn’t exist in Ghost's default helpers. For our logic to work, we must escape this helper so that it’s not treated as a helper by Ghost’s built-in Handlebars.</p>

<p>The correct way is to write this helper as \{{hello_world}}. This way, Ghost treats it as plain text. After refreshing the Ghost homepage, you should see the plain text {{hello_world}}. If this happens, you are on the right track. Let’s now return to the middleware server file, where we will use the response decorator.</p>

<p>⚠️ Remember to escape custom helpers in your theme! Don’t forget to add the \ character.<br>
</p>

<pre class="brush:php;toolbar:false">let htmlContent = proxyResData.toString('utf8');
로그인 후 복사

미들웨어 서버를 다시 시작하고 위 헬퍼를 등록하면 헬퍼가 반환한 텍스트와 현재 날짜 및 시간과 함께 렌더링된 헬퍼가 브라우저에 표시됩니다.

이 단계에서는 미들웨어 서버 코드에 추가할 추가 사용자 정의 도우미를 사용하여 Ghost 테마를 확장할 수 있습니다.

보안

언젠가는 도우미와 함께 다양한 물건을 돌려주고 싶을 수도 있습니다. 기본적으로 라이브러리는 XSS 공격으로부터 보호하지만 SafeString 메서드를 사용하면 이 보호 기능이 작동하지 않습니다. 가능하면 사용하지 마세요.

또 하나! 사용자가 게시물 아래 댓글 섹션에 이러한 도우미를 추가하고 매개변수에 악성 콘텐츠를 추가한다고 상상해 보세요. 보안에 유의하세요. 예를 들어 모든 HTML을 완전히 렌더링하면 XSS 공격에 취약할 수 있습니다. 특정 폐쇄 영역에서 Handlebars.js를 컴파일하고 렌더링하는 것이 좋습니다. 필요한 경우 HTML을 구문 분석하고 핸들바를 렌더링하기 위해 Cherio(https://cheerio.js.org/) 라이브러리를 사용할 수 있습니다. 다음은 이전 렌더링 코드를 수정하여 자신을 보호할 수 있는 방법의 예입니다.

const path = require('path');

module.exports = {
    activate: function activate(ghost) {
        ghost.helperService.registerDir(path.resolve(__dirname, './lib/helpers'));
    }
};
로그인 후 복사
로그인 후 복사
로그인 후 복사

스크립트 시작 부분에 라이브러리 초기화를 추가하는 것을 잊지 마세요: const asyncHelpers = require('handlebars-async-helpers');. handlerbars-async-helpers와 핸들바 간의 버전 충돌로 인해 설치하는 데 문제가 발생하는 경우 핸들바를 ^4.7.6으로 다운그레이드하세요. 안타깝게도 비동기 도우미 라이브러리는 한동안 유지되지 않았지만 실제로는 여전히 작동합니다.

데이터베이스 통신 및 개체

예를 들어 현재 게시물을 가져오기 위해 Ghost에서 데이터베이스 쿼리를 만들고 싶다면 가능하며 어렵지 않습니다. 명확하고 빠른 SQL 쿼리 빌더인 knex(https://knexjs.org/)와 같은 라이브러리를 사용할 수 있습니다. 이를 위해서는 handlerbars-async-helpers가 필요하다는 점을 기억하세요. Ghost의 데이터베이스에 연결하려면 knex를 올바르게 구성하세요.

knex를 db 변수로 초기화하고 다음 코드를 시도해 보세요.

const {SafeString, escapeExpression} = require('../../../../services/handlebars');

module.exports = function uppercase(text) {
    return `${text.toUpperCase()}`;
};
로그인 후 복사
로그인 후 복사
로그인 후 복사

그런 다음 Ghost 테마의 post.hbs 템플릿에 다음 도우미를 추가하세요: {{post_title uuid="{{uuid}}"}}. 이 예에서는 {{uuid}}가 Ghost에서 사용 가능한 도우미로 검색 및 전달되어 도우미의 uuid 필드를 채우고 사용자 정의 도우미가 게시물 제목을 표시하게 합니다.

Axios를 사용하여 Ghost Content API에 HTTP 요청을 할 수도 있지만 이는 직접 데이터베이스 통신보다 속도가 상당히 느립니다.

성능

미들웨어 기반 솔루션이 속도 측면에서 최고가 아닐 수도 있다는 것을 알고 있지만 개인적으로 이 솔루션을 사용하고 있는데 페이지 로드 시간이 크게 떨어지는 것을 느끼지 못했습니다. 단일 요청의 평균 응답 시간은 100ms 미만이었고(express-status-monitor에 따르면) 모든 페이지의 데이터베이스에서 일부 값을 검색하는 사용자 지정 도우미를 사용합니다.

물론 캐싱 메커니즘을 추가하여 미들웨어 성능을 향상하거나 express-http-proxy 대신 대체 솔루션을 사용할 수도 있습니다.

아키텍처 구현

Docker 또는 다른 컨테이너화 메커니즘을 사용합니다. 나는 그것을 내 프로젝트에 사용했는데 훌륭하게 작동합니다. Ghost, Nginx 및 Node.js 이미지용 Ghost 및 데이터베이스 이미지를 추가합니다. 공유 네트워크(드라이버: 브리지)에 연결하고 그에 따라 Nginx와 Node.js 서버를 구성하세요. 모두 매우 간단합니다!

위 내용은 Ghost에서 맞춤형 핸들바 도우미를 만들어보세요!의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 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 옷 제거제

Video Face Swap

Video Face Swap

완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

<gum> : Bubble Gum Simulator Infinity- 로얄 키를 얻고 사용하는 방법
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
Nordhold : Fusion System, 설명
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
Mandragora : 마녀 트리의 속삭임 - Grappling Hook 잠금 해제 방법
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

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

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

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

JavaScript 엔진 : 구현 비교 JavaScript 엔진 : 구현 비교 Apr 13, 2025 am 12:05 AM

각각의 엔진의 구현 원리 및 최적화 전략이 다르기 때문에 JavaScript 엔진은 JavaScript 코드를 구문 분석하고 실행할 때 다른 영향을 미칩니다. 1. 어휘 분석 : 소스 코드를 어휘 단위로 변환합니다. 2. 문법 분석 : 추상 구문 트리를 생성합니다. 3. 최적화 및 컴파일 : JIT 컴파일러를 통해 기계 코드를 생성합니다. 4. 실행 : 기계 코드를 실행하십시오. V8 엔진은 즉각적인 컴파일 및 숨겨진 클래스를 통해 최적화하여 Spidermonkey는 유형 추론 시스템을 사용하여 동일한 코드에서 성능이 다른 성능을 제공합니다.

Python vs. JavaScript : 학습 곡선 및 사용 편의성 Python vs. JavaScript : 학습 곡선 및 사용 편의성 Apr 16, 2025 am 12:12 AM

Python은 부드러운 학습 곡선과 간결한 구문으로 초보자에게 더 적합합니다. JavaScript는 가파른 학습 곡선과 유연한 구문으로 프론트 엔드 개발에 적합합니다. 1. Python Syntax는 직관적이며 데이터 과학 및 백엔드 개발에 적합합니다. 2. JavaScript는 유연하며 프론트 엔드 및 서버 측 프로그래밍에서 널리 사용됩니다.

C/C에서 JavaScript까지 : 모든 것이 어떻게 작동하는지 C/C에서 JavaScript까지 : 모든 것이 어떻게 작동하는지 Apr 14, 2025 am 12:05 AM

C/C에서 JavaScript로 전환하려면 동적 타이핑, 쓰레기 수집 및 비동기 프로그래밍으로 적응해야합니다. 1) C/C는 수동 메모리 관리가 필요한 정적으로 입력 한 언어이며 JavaScript는 동적으로 입력하고 쓰레기 수집이 자동으로 처리됩니다. 2) C/C를 기계 코드로 컴파일 해야하는 반면 JavaScript는 해석 된 언어입니다. 3) JavaScript는 폐쇄, 프로토 타입 체인 및 약속과 같은 개념을 소개하여 유연성과 비동기 프로그래밍 기능을 향상시킵니다.

JavaScript 및 웹 : 핵심 기능 및 사용 사례 JavaScript 및 웹 : 핵심 기능 및 사용 사례 Apr 18, 2025 am 12:19 AM

웹 개발에서 JavaScript의 주요 용도에는 클라이언트 상호 작용, 양식 검증 및 비동기 통신이 포함됩니다. 1) DOM 운영을 통한 동적 컨텐츠 업데이트 및 사용자 상호 작용; 2) 사용자가 사용자 경험을 향상시키기 위해 데이터를 제출하기 전에 클라이언트 확인이 수행됩니다. 3) 서버와의 진실한 통신은 Ajax 기술을 통해 달성됩니다.

자바 스크립트 행동 : 실제 예제 및 프로젝트 자바 스크립트 행동 : 실제 예제 및 프로젝트 Apr 19, 2025 am 12:13 AM

실제 세계에서 JavaScript의 응용 프로그램에는 프론트 엔드 및 백엔드 개발이 포함됩니다. 1) DOM 운영 및 이벤트 처리와 관련된 TODO 목록 응용 프로그램을 구축하여 프론트 엔드 애플리케이션을 표시합니다. 2) Node.js를 통해 RESTFULAPI를 구축하고 Express를 통해 백엔드 응용 프로그램을 시연하십시오.

JavaScript 엔진 이해 : 구현 세부 사항 JavaScript 엔진 이해 : 구현 세부 사항 Apr 17, 2025 am 12:05 AM

보다 효율적인 코드를 작성하고 성능 병목 현상 및 최적화 전략을 이해하는 데 도움이되기 때문에 JavaScript 엔진이 내부적으로 작동하는 방식을 이해하는 것은 개발자에게 중요합니다. 1) 엔진의 워크 플로에는 구문 분석, 컴파일 및 실행; 2) 실행 프로세스 중에 엔진은 인라인 캐시 및 숨겨진 클래스와 같은 동적 최적화를 수행합니다. 3) 모범 사례에는 글로벌 변수를 피하고 루프 최적화, Const 및 Lets 사용 및 과도한 폐쇄 사용을 피하는 것이 포함됩니다.

Python vs. JavaScript : 커뮤니티, 라이브러리 및 리소스 Python vs. JavaScript : 커뮤니티, 라이브러리 및 리소스 Apr 15, 2025 am 12:16 AM

Python과 JavaScript는 커뮤니티, 라이브러리 및 리소스 측면에서 고유 한 장점과 단점이 있습니다. 1) Python 커뮤니티는 친절하고 초보자에게 적합하지만 프론트 엔드 개발 리소스는 JavaScript만큼 풍부하지 않습니다. 2) Python은 데이터 과학 및 기계 학습 라이브러리에서 강력하며 JavaScript는 프론트 엔드 개발 라이브러리 및 프레임 워크에서 더 좋습니다. 3) 둘 다 풍부한 학습 리소스를 가지고 있지만 Python은 공식 문서로 시작하는 데 적합하지만 JavaScript는 MDNWebDocs에서 더 좋습니다. 선택은 프로젝트 요구와 개인적인 이익을 기반으로해야합니다.

Python vs. JavaScript : 개발 환경 및 도구 Python vs. JavaScript : 개발 환경 및 도구 Apr 26, 2025 am 12:09 AM

개발 환경에서 Python과 JavaScript의 선택이 모두 중요합니다. 1) Python의 개발 환경에는 Pycharm, Jupyternotebook 및 Anaconda가 포함되어 있으며 데이터 과학 및 빠른 프로토 타이핑에 적합합니다. 2) JavaScript의 개발 환경에는 Node.js, VScode 및 Webpack이 포함되어 있으며 프론트 엔드 및 백엔드 개발에 적합합니다. 프로젝트 요구에 따라 올바른 도구를 선택하면 개발 효율성과 프로젝트 성공률이 향상 될 수 있습니다.

See all articles