Hike News
Hike News

Hexo FAQ

hexo를 설치하는 방법을 알려주세요

ChatGPT:

  • Hexo는 빠르고 간단한 정적 웹사이트 생성기로, Node.js를 기반으로 합니다. 아래는 Hexo를 설치하는 간단한 방법입니다:

참고: Hexo를 설치하기 전에, 컴퓨터에 Node.js가 설치되어 있어야 합니다. Node.js를 설치하지 않았다면, Node.js 공식 웹사이트(https://nodejs.org)에서 최신 버전을 다운로드하여 설치해 주세요.

  1. npm 설치 확인:
    터미널 또는 명령 프롬프트를 열고, npm (Node.js 패키지 관리자)가 설치되어 있는지 확인합니다. 다음 명령어를 실행하여 npm이 설치되었는지 확인합니다.
1
2

npm -v
  1. Hexo 설치:
    터미널 또는 명령 프롬프트에서 다음 명령어를 실행하여 Hexo를 설치합니다.
1
2

npm install -g hexo-cli

위 명령을 실행하면, Hexo CLI(Command Line Interface)가 글로벌하게 설치됩니다.

  1. Hexo 프로젝트 생성:
    Hexo CLI가 설치되면, 원하는 디렉토리에서 Hexo 프로젝트를 생성할 수 있습니다. 예를 들어, 웹사이트를 생성할 새로운 디렉토리를 만들고 그 안에서 다음 명령어를 실행합니다.
1
2
3
4

hexo init my_website
cd my_website
npm install

위의 명령어는 “my_website”라는 이름의 새로운 Hexo 프로젝트를 생성합니다. 프로젝트 디렉토리로 이동하고, 필요한 종속성 패키지를 설치합니다.

  1. Hexo 서버 실행:
    Hexo 프로젝트를 성공적으로 생성한 후, 다음 명령어를 실행하여 개발 서버를 시작합니다.
1
2

hexo server

서버를 시작한 후, 웹 브라우저에서 http://localhost:4000로 접속하면 Hexo 웹사이트를 확인할 수 있습니다. 변경 사항을 실시간으로 볼 수 있고, 정적 파일이 생성되는 것을 확인할 수 있습니다.

이제 Hexo를 설치하고 개발 서버를 실행하는 방법을 알게 되었습니다. Hexo는 다양한 테마와 플러그인을 지원하므로, 원하는 방식으로 웹사이트를 커스터마이징할 수 있습니다. 추가적인 정보는 Hexo 공식 문서를 참조하시기 바랍니다.

hexo에서 홈페이지 정보를 바꾸는 방법을 알려주세요

ChatGPT:

  • Hexo에서 홈페이지 정보를 바꾸려면 주로 두 가지 설정 파일을 수정해야 합니다. 이 설정 파일들은 Hexo 프로젝트의 루트 디렉토리에 위치합니다. 아래는 이 설정 파일들과 그 안에서 수정해야 할 내용을 설명합니다:
  1. _config.yml 파일:
    이 파일은 Hexo 웹사이트의 전반적인 설정을 담고 있습니다. 웹사이트의 제목, 설명, 작성자 정보, 언어, 테마 등의 정보를 수정할 수 있습니다.

다음은 일반적으로 수정하게 되는 몇 가지 항목들입니다:

  • title: 웹사이트 제목
  • subtitle: 웹사이트 부제목 또는 설명
  • author: 작성자 이름
  • language: 웹사이트 언어 설정
  • timezone: 웹사이트 시간대 설정
  • theme: 사용할 테마 설정 (테마를 변경하려면 미리 해당 테마를 설치해야 합니다)

수정 방법:
_config.yml 파일을 텍스트 편집기로 열고 원하는 항목들을 수정합니다. 수정 후에는 저장하고 닫습니다.

  1. source/_data/ 디렉토리의 site.js 파일:
    이 파일은 웹사이트의 정보를 더 상세하게 정의하는 파일입니다. _config.yml 파일에서 설정한 몇 가지 정보들은 site.js 파일에서 더 자세하게 표현할 수 있습니다.

다음은 site.js 파일에서 수정할 수 있는 몇 가지 항목들입니다:

  • description: 웹사이트에 대한 더 상세한 설명
  • url: 웹사이트의 URL (주의: 이 설정을 바꿀 때는 기존에 생성된 정적 파일들을 모두 삭제하고 hexo clean 명령을 실행해야 합니다)
  • author: 작성자 정보 (예: 이름, 이메일, 소셜 미디어 등)
  • 기타 등등…

수정 방법:
source/_data/ 디렉토리 안에 있는 site.js 파일을 텍스트 편집기로 열고 원하는 항목들을 수정합니다. 수정 후에는 저장하고 닫습니다.

위의 설정 파일들을 수정한 후에는, 변경 사항이 적용되도록 Hexo를 다시 빌드해야 합니다. 터미널 또는 명령 프롬프트에서 프로젝트 디렉토리로 이동한 다음 다음 명령어를 실행합니다:

1
2
3

hexo clean # 기존 정적 파일들을 삭제
hexo generate # 새로운 정적 파일들 생성

변경 사항이 성공적으로 적용되면, hexo server 명령을 실행하여 웹사이트를 확인하고 테스트할 수 있습니다.

hexo에서 theme를 바꾸는 방법을 알려주세요

ChatGPT:

  • Hexo에서 테마를 바꾸는 방법은 간단합니다. 원하는 테마를 설치하고, _config.yml 파일에서 테마 설정을 변경하는 것으로 가능합니다. 아래는 테마를 바꾸는 단계를 설명합니다:
  1. 테마 설치:
    Hexo에서 사용 가능한 다양한 테마들이 있습니다. 먼저, 원하는 테마를 선택하고 해당 테마의 GitHub 저장소 또는 npm 패키지를 확인합니다.

테마를 GitHub 저장소로부터 설치하려면, 터미널 또는 명령 프롬프트에서 Hexo 프로젝트의 루트 디렉토리로 이동한 후 다음 명령어를 실행합니다:

1
2

git clone <테마 GitHub 저장소 URL> themes/<테마 폴더 이름>

예를 들어, landscape라는 테마를 설치하려면 다음과 같이 실행합니다:

1
2

git clone https://github.com/hexojs/hexo-theme-landscape.git themes/landscape

테마를 npm 패키지로부터 설치하려면, 터미널 또는 명령 프롬프트에서 Hexo 프로젝트의 루트 디렉토리로 이동한 후 다음 명령어를 실행합니다:

1
2

npm install <테마 npm 패키지 이름> --save

예를 들어, next라는 테마를 설치하려면 다음과 같이 실행합니다:

1
2

npm install hexo-theme-next --save
  1. 테마 설정 변경:
    테마를 설치한 후, 테마를 사용하도록 Hexo 프로젝트의 _config.yml 파일에서 테마 설정을 변경합니다.

_config.yml 파일을 텍스트 편집기로 열고, 다음과 같이 theme 항목을 테마의 이름으로 변경합니다. 테마 폴더 이름과 _config.yml 파일의 설정 이름이 일치해야 합니다.

1
2

theme: <테마 폴더 이름>

예를 들어, landscape 테마를 사용하려면 _config.yml 파일에서 다음과 같이 변경합니다:

1
2

theme: landscape
  1. Hexo 빌드:
    테마를 변경한 후, 변경 사항이 적용되도록 Hexo를 다시 빌드해야 합니다. 터미널 또는 명령 프롬프트에서 프로젝트 디렉토리로 이동한 다음 다음 명령어를 실행합니다:
1
2
3

hexo clean # 기존 정적 파일들을 삭제
hexo generate # 새로운 정적 파일들 생성

변경 사항이 성공적으로 적용되면, hexo server 명령을 실행하여 웹사이트를 확인하고 테스트할 수 있습니다. 선택한 테마의 스타일과 레이아웃이 적용된 것을 볼 수 있습니다.

이제 테마를 성공적으로 변경했습니다. 원하는 테마를 찾아서 설치하고 적용하여 멋진 Hexo 웹사이트를 만들어보세요!

hexo에서 about 페이지 만드는 방법은?

ChatGPT:

  • Hexo에서 About 페이지를 만들려면 다음과 같은 단계를 따라서 진행할 수 있습니다:
  1. About 페이지 생성:
    About 페이지를 만들기 위해 Hexo에게 새로운 페이지를 생성하도록 지시해야 합니다. 터미널 또는 명령 프롬프트에서 Hexo 프로젝트의 루트 디렉토리로 이동한 다음 다음 명령어를 실행합니다:
1
2

hexo new page about

위 명령을 실행하면, source/about/index.md 파일이 생성됩니다. 이 파일이 About 페이지의 내용을 담고 있습니다.

  1. About 페이지 내용 편집:
    source/about/index.md 파일을 텍스트 편집기로 열어 About 페이지의 내용을 편집합니다. Markdown 형식을 사용하여 내용을 작성할 수 있습니다. Markdown을 사용하여 원하는 텍스트, 이미지, 링크 등을 추가할 수 있습니다.

예를 들어, 다음과 같이 기본적인 내용을 추가할 수 있습니다:

1
2
3
4
5
6
7
8
9

---
title: About Me
layout: page
---

# About Me

안녕하세요! 저는 Hexo를 이용하여 만든 웹사이트에 대해 소개하는 페이지입니다. 여기에 자기소개를 작성하세요!
  1. About 페이지 설정:
    About 페이지의 레이아웃을 설정하기 위해 source/about/index.md 파일의 상단에 YAML Front Matter를 사용합니다. YAML Front Matter는 페이지에 대한 메타데이터를 지정하는 데 사용됩니다. 위 예제에서는 titlelayout을 설정했습니다.
  • title: 페이지의 제목을 설정합니다.
  • layout: About 페이지를 렌더링하는 데 사용할 레이아웃을 설정합니다. Hexo 테마마다 레이아웃 이름이 다를 수 있으므로, 해당 테마의 레이아웃 이름을 사용합니다. 대부분의 테마에서 About 페이지에는 page 또는 about 레이아웃을 사용합니다.
  1. About 페이지 빌드:
    About 페이지의 내용을 작성하고 설정을 완료했다면, 변경 사항이 적용되도록 Hexo를 다시 빌드합니다. 터미널 또는 명령 프롬프트에서 프로젝트 디렉토리로 이동한 다음 다음 명령어를 실행합니다:
1
2
3

hexo clean # 기존 정적 파일들을 삭제
hexo generate # 새로운 정적 파일들 생성

변경 사항이 성공적으로 적용되면, About 페이지가 Hexo 웹사이트에 추가됩니다. About 페이지의 URL은 http://yourdomain.com/about/ 혹은 http://localhost:4000/about/와 같이 설정한 도메인 뒤에 “/about/“ 경로로 접속할 수 있습니다.

이제 About 페이지를 성공적으로 만들었습니다. 원하는 방식으로 About 페이지를 디자인하고 내용을 추가하여 웹사이트에 더 많은 정보를 제공할 수 있습니다.

hexo generate 했을 때 생성되는 폴더는 어디인가요?

ChatGPT:

  • Hexo에서 hexo generate 명령을 실행하면, 정적 웹사이트 파일이 생성되는 폴더는 기본적으로 Hexo 프로젝트의 루트 디렉토리 안에 있는 public 폴더입니다. 이 폴더에는 HTML, CSS, JavaScript 및 이미지와 같은 모든 웹사이트 파일이 포함됩니다.

정적 웹사이트 파일이 생성된 후에는 웹서버를 실행하거나 해당 폴더의 내용을 웹 호스팅 서비스 또는 웹 서버에 업로드하여 웹사이트를 온라인으로 공유할 수 있습니다.

기본적으로 hexo generate 명령을 실행하면 Hexo는 프로젝트의 source 디렉토리 안에 있는 Markdown 파일들과 테마의 레이아웃, CSS, JavaScript 등을 사용하여 웹사이트를 빌드하고 public 폴더에 결과물을 저장합니다.

이후 hexo server 명령을 실행하면, Hexo는 public 폴더의 내용을 웹 서버로 제공하여 로컬에서 웹사이트를 확인할 수 있습니다. hexo server를 실행한 후에는 브라우저에서 http://localhost:4000으로 접속하여 웹사이트를 확인할 수 있습니다.

따라서 정적 웹사이트 파일은 기본적으로 public 폴더 안에 생성되며, 이 폴더의 내용을 웹서버나 웹 호스팅 서비스에 업로드하여 웹사이트를 호스팅할 수 있습니다.

hexo에서 categories를 만드는 방법은?

ChatGPT:

  • Hexo에서 카테고리(Category)를 만들려면 다음과 같은 단계를 따라서 진행할 수 있습니다:
  1. 새로운 카테고리 생성:
    터미널 또는 명령 프롬프트에서 Hexo 프로젝트의 루트 디렉토리로 이동한 다음 다음 명령어를 실행하여 새로운 카테고리를 생성합니다.
1
2

hexo new page <카테고리 이름>

예를 들어, programming이라는 이름의 카테고리를 생성하려면 다음과 같이 실행합니다.

1
2

hexo new page programming

위 명령을 실행하면 source/programming/index.md 파일이 생성됩니다. 이 파일이 새로운 카테고리의 페이지를 나타냅니다.

  1. 카테고리 페이지 내용 편집:
    source/programming/index.md 파일을 텍스트 편집기로 열어 카테고리 페이지의 내용을 편집합니다. Markdown 형식을 사용하여 페이지의 내용을 작성할 수 있습니다. 해당 카테고리에 속하는 글들을 표시하는데 사용할 수도 있습니다.

예를 들어, 다음과 같이 기본적인 내용을 추가할 수 있습니다:

1
2
3
4
5

---
title: Programming
layout: category
---

위 YAML Front Matter에서 title은 카테고리 페이지의 제목을 설정하며, layout은 카테고리 페이지에 사용할 레이아웃을 지정합니다. layout로는 대개 “category” 또는 “index” 레이아웃을 사용합니다.

  1. 카테고리 페이지 설정:
    카테고리 페이지의 레이아웃을 설정하기 위해 source/programming/index.md 파일의 상단에 YAML Front Matter를 사용합니다. YAML Front Matter는 페이지에 대한 메타데이터를 지정하는 데 사용됩니다.
  2. Hexo 빌드:
    카테고리 페이지의 내용을 작성하고 설정을 완료했다면, 변경 사항이 적용되도록 Hexo를 다시 빌드합니다. 터미널 또는 명령 프롬프트에서 프로젝트 디렉토리로 이동한 다음 다음 명령어를 실행합니다:
1
2
3

hexo clean # 기존 정적 파일들을 삭제
hexo generate # 새로운 정적 파일들 생성

변경 사항이 성공적으로 적용되면, 새로운 카테고리 페이지가 Hexo 웹사이트에 추가됩니다. 해당 카테고리에 속하는 글들은 이제 이 페이지에 표시됩니다.

이제 카테고리를 성공적으로 만들었습니다. 원하는 방식으로 카테고리 페이지를 디자인하고 내용을 추가하여 웹사이트의 카테고리 구조를 조직화할 수 있습니다.

Hexo에서 post 순서를 변경하는 방법은?

ChatGPT:

  • Hexo에서 포스트(Post) 순서를 변경하려면 YAML Front Matter를 사용하여 포스트에 날짜를 지정해야 합니다. 포스트는 YAML Front Matter에 지정된 날짜 순서대로 정렬되어 웹사이트에 표시됩니다. 따라서 날짜를 변경함으로써 포스트의 순서를 조정할 수 있습니다.

포스트의 날짜를 변경하는 방법은 다음과 같습니다:

  1. 특정 포스트의 날짜 변경:
    특정 포스트의 날짜를 변경하려면, 해당 포스트의 Markdown 파일을 텍스트 편집기로 열고 YAML Front Matter 부분에서 date를 변경합니다. 날짜 형식은 YYYY-MM-DD HH:mm:ss 또는 YYYY-MM-DD로 지정해야 합니다.

예를 들어, 포스트의 날짜를 2023년 8월 1일로 변경하려면 다음과 같이 작성합니다:

1
2
3
4
5
6
7

---
title: My Post
date: 2023-08-01 12:00:00
---

포스트의 내용입니다.

변경한 날짜로 포스트가 정렬되어 웹사이트에 표시됩니다.

  1. 다수의 포스트 날짜 변경:
    여러 포스트의 날짜를 일괄적으로 변경하려면, 해당 포스트들의 Markdown 파일을 편집하면 됩니다. 각 포스트의 YAML Front Matter에서 date를 수정하여 날짜를 변경합니다.

포스트들의 날짜를 변경한 후에는 Hexo를 다시 빌드하여 변경 사항이 반영되도록 합니다. 터미널 또는 명령 프롬프트에서 프로젝트 디렉토리로 이동한 다음 다음 명령어를 실행합니다:

1
2
3

hexo clean # 기존 정적 파일들을 삭제
hexo generate # 새로운 정적 파일들 생성

위의 명령어를 실행하면, 변경한 날짜에 따라 포스트들이 정렬되어 Hexo 웹사이트에 표시됩니다.

날짜를 변경하여 포스트의 순서를 조정할 수 있으며, 이를 이용하여 원하는 방식으로 포스트들을 정렬하여 웹사이트에 노출시킬 수 있습니다.

hexo에서 문자열 검색이 가능하게 하는 플러그인 은?

ChatGPT:

  • Hexo에서 문자열 검색 기능을 추가하기 위해 hexo-generator-search 플러그인을 사용할 수 있습니다. 이 플러그인은 Hexo 웹사이트에 검색 기능을 구현하기 위해 필요한 검색 데이터를 생성해주는 역할을 합니다.

hexo-generator-search 플러그인을 설치하고 설정하는 방법은 다음과 같습니다:

  1. 플러그인 설치:
    터미널 또는 명령 프롬프트에서 Hexo 프로젝트의 루트 디렉토리로 이동한 다음, 다음 명령어를 실행하여 hexo-generator-search 플러그인을 설치합니다.
1
2

npm install hexo-generator-search --save
  1. _config.yml 설정:
    hexo-generator-search 플러그인을 설치한 후, Hexo 프로젝트의 _config.yml 파일에 아래와 같이 설정을 추가합니다.
1
2
3
4

search:
path: search.xml
field: post
  • path: 검색 데이터가 생성될 파일의 경로를 설정합니다. 이 예제에서는 search.xml 파일로 지정되어 있습니다. 이 파일은 Hexo 웹사이트에 포함된 검색 데이터를 포함하게 됩니다.
  • field: 검색 대상을 설정합니다. post로 설정하면 포스트 제목과 내용을 대상으로 검색이 가능합니다. 다른 값을 지정하면 다른 대상을 검색할 수 있습니다.
  1. 검색 데이터 생성:
    _config.yml 파일을 수정한 후, 터미널 또는 명령 프롬프트에서 다음 명령어를 실행하여 검색 데이터를 생성합니다.
1
2

hexo generate

위 명령을 실행하면 search.xml 파일이 Hexo 웹사이트의 public 폴더 안에 생성됩니다. 이 파일에는 검색 기능을 위한 데이터가 포함되어 있습니다.

  1. 검색 기능 추가:
    검색 데이터를 생성한 후에는 Hexo 테마의 검색 기능을 지원하는 템플릿과 스크립트를 추가해야 합니다. 각 테마마다 다양한 방법으로 검색 기능을 추가하는 방법이 다를 수 있습니다. 테마의 공식 문서를 확인하거나, 검색 기능과 관련된 템플릿 또는 스크립트를 수정하여 검색 기능을 구현합니다.

검색 기능을 추가한 후에는 Hexo 웹사이트에서 문자열 검색이 가능하게 됩니다. 사용자가 원하는 키워드를 검색창에 입력하면, 검색 결과로 해당 키워드와 일치하는 포스트들이 표시됩니다.

hexo-generator-search 플러그인을 통해 Hexo 웹사이트에 검색 기능을 추가할 수 있으며, 사용자 편의성과 웹사이트의 유용성을 향상시킬 수 있습니다.

hexo에서 Home 페이지 설정법

ChatGPT:

  • Hexo에서 Home 페이지를 설정하기 위해 _config.yml 파일을 수정하면 됩니다. Home 페이지는 보통 최상위 루트 URL (예: http://yourdomain.com/ 또는 http://localhost:4000/)에서 접속했을 때 나타나는 기본 페이지를 말합니다.

Home 페이지를 설정하는 방법은 다음과 같습니다:

  1. _config.yml 파일 열기:
    Hexo 프로젝트의 루트 디렉토리에 있는 _config.yml 파일을 텍스트 편집기로 엽니다.
  2. Home 페이지 설정 변경:
    _config.yml 파일에서 default_layout 항목을 찾아 아래와 같이 변경합니다.
1
2

default_layout: <레이아웃 이름>

위에서 <레이아웃 이름> 자리에 원하는 레이아웃의 이름을 입력합니다. 대개 테마마다 Home 페이지에 사용되는 기본 레이아웃 이름은 index 또는 home입니다.

예를 들어, index 레이아웃을 Home 페이지로 설정하려면 아래와 같이 변경합니다:

1
2

default_layout: index
  1. Hexo 빌드:
    _config.yml 파일을 수정한 후, Hexo를 다시 빌드하여 변경 사항이 반영되도록 합니다. 터미널 또는 명령 프롬프트에서 프로젝트 디렉토리로 이동한 다음 다음 명령어를 실행합니다:
1
2
3

hexo clean # 기존 정적 파일들을 삭제
hexo generate # 새로운 정적 파일들 생성

변경한 Home 페이지 설정이 성공적으로 적용되면, Hexo 웹사이트의 최상위 루트 URL에서 해당 레이아웃이 사용되어 보일 것입니다.

이제 Home 페이지를 성공적으로 설정하였습니다. Home 페이지에는 주로 최신 글 목록 또는 웹사이트의 주요 내용이 표시되는데, 원하는 방식으로 레이아웃을 디자인하여 Home 페이지를 꾸며보세요.

hexo에서 상단메뉴 만드는 법

ChatGPT:

  • Hexo에서 상단 메뉴를 만들려면 다음과 같은 단계를 따라 진행할 수 있습니다:
  1. 테마의 설정 파일 확인:
    먼저, 사용 중인 Hexo 테마의 설정 파일을 확인해야 합니다. 테마마다 상단 메뉴를 추가하는 방법이 다를 수 있기 때문입니다. 대부분의 테마는 _config.yml 파일에 메뉴 설정을 담고 있습니다.
  2. 메뉴 추가:
    테마의 설정 파일을 열어 메뉴를 추가하거나 수정합니다. 대개 메뉴는 배열 형태로 구성되며, 각 메뉴 항목은 이름과 해당 메뉴를 클릭했을 때 이동할 주소(URL)를 지정합니다.

예를 들어, _config.yml 파일에서 메뉴를 다음과 같이 추가할 수 있습니다:

1
2
3
4
5
6
7
8
9
10

menu:
- name: Home
link: /
- name: About
link: /about/
- name: Blog
link: /archives/
- name: Contact
link: /contact/

위 예제에서는 Home, About, Blog, Contact 등의 메뉴 항목이 상단 메뉴로 추가되었습니다. name은 메뉴 항목의 이름을, link는 해당 메뉴를 클릭했을 때 이동할 주소를 지정합니다.

  1. Hexo 빌드:
    메뉴를 추가하거나 수정한 후, Hexo를 다시 빌드하여 변경 사항이 반영되도록 합니다. 터미널 또는 명령 프롬프트에서 프로젝트 디렉토리로 이동한 다음 다음 명령어를 실행합니다:
1
2
3

hexo clean # 기존 정적 파일들을 삭제
hexo generate # 새로운 정적 파일들 생성

변경한 메뉴가 성공적으로 적용되면, Hexo 웹사이트의 상단에 추가한 메뉴 항목들이 표시될 것입니다.

테마마다 메뉴를 추가하는 방법이 다를 수 있으므로, 사용 중인 테마의 공식 문서나 README 파일을 참고하여 상단 메뉴를 만드는 방법을 확인해보세요. 사용 중인 테마에 따라 커스터마이징 옵션 및 메뉴 스타일을 변경할 수도 있습니다.

hexo에서 서브메뉴를 만드는 방법은?

ChatGPT:

  • Hexo에서 서브메뉴를 만들려면 주로 테마의 설정 파일에서 메뉴 항목을 중첩하는 방법을 사용합니다. 서브메뉴는 메인 메뉴 아래에 드롭다운 형태로 추가되는 메뉴 항목들을 의미합니다.

서브메뉴를 만드는 방법은 다음과 같습니다:

  1. 테마의 설정 파일 열기:
    먼저, 사용 중인 Hexo 테마의 설정 파일을 확인해야 합니다. 대부분의 테마는 _config.yml 파일에 메뉴 설정을 담고 있습니다.
  2. 서브메뉴 추가:
    서브메뉴를 만들기 위해서는 메인 메뉴 항목과 그에 해당하는 서브메뉴 항목들을 중첩 구조로 설정해야 합니다. 대부분의 테마에서는 메뉴를 배열 안에 중첩하여 정의할 수 있습니다.

예를 들어, _config.yml 파일에서 서브메뉴를 다음과 같이 추가할 수 있습니다:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16

menu:
- name: Home
link: /
- name: About
link: /about/
- name: Blog
link: /archives/
- name: Contact
link: /contact/
- name: Projects
sub:
- name: Project 1
link: /projects/project1/
- name: Project 2
link: /projects/project2/

위 예제에서는 Projects라는 메인 메뉴 아래에 Project 1과 Project 2라는 서브메뉴 항목들을 추가하였습니다. Projects 메뉴 항목에 sub 키를 추가하고 그 안에 서브메뉴 항목들을 배열 형태로 정의합니다.

  1. Hexo 빌드:
    서브메뉴를 추가한 후, Hexo를 다시 빌드하여 변경 사항이 반영되도록 합니다. 터미널 또는 명령 프롬프트에서 프로젝트 디렉토리로 이동한 다음 다음 명령어를 실행합니다:
1
2
3

hexo clean # 기존 정적 파일들을 삭제
hexo generate # 새로운 정적 파일들 생성

변경한 서브메뉴가 성공적으로 적용되면, Hexo 웹사이트의 메뉴에 서브메뉴 항목들이 표시될 것입니다.

테마마다 서브메뉴를 추가하는 방법이 다를 수 있으므로, 사용 중인 테마의 공식 문서나 README 파일을 참고하여 서브메뉴를 만드는 방법을 확인해보세요. 사용 중인 테마에 따라 커스터마이징 옵션 및 서브메뉴 스타일을 변경할 수도 있습니다.

hexo에서 특정 폴더에 있는 정적이미지 가져오기

ChatGPT:

  • Hexo에서 특정 폴더에 있는 정적 이미지를 가져오려면 다음과 같은 단계를 따라서 진행할 수 있습니다:
  1. 이미지 폴더 생성:
    먼저, Hexo 프로젝트의 source 폴더 내에 이미지를 담을 새로운 폴더를 생성합니다. 예를 들어, images라는 폴더를 생성합니다.
  2. 이미지 추가:
    이미지를 images 폴더에 추가합니다. 원하는 형식의 이미지 파일(JPG, PNG, GIF 등)을 해당 폴더에 넣어줍니다.
  3. 이미지 경로 지정:
    Markdown 파일에서 이미지를 특정 폴더에 있는 이미지로 사용하기 위해서는 이미지의 상대 경로를 지정해야 합니다.

Markdown 파일에서 이미지를 추가하려면 아래와 같이 이미지 경로를 지정합니다:

1
2

![이미지 설명](/images/image_name.jpg)

위 예시에서 /images/는 이미지 폴더의 경로이고, image_name.jpg는 해당 폴더에 있는 이미지 파일의 이름입니다. 이미지 파일의 이름과 확장자를 사용하여 이미지를 포함시킵니다.

  1. Hexo 빌드:
    이미지 경로를 지정한 후, Hexo를 다시 빌드하여 변경 사항이 반영되도록 합니다. 터미널 또는 명령 프롬프트에서 프로젝트 디렉토리로 이동한 다음 다음 명령어를 실행합니다:
1
2
3

hexo clean # 기존 정적 파일들을 삭제
hexo generate # 새로운 정적 파일들 생성

변경한 이미지가 성공적으로 적용되면, Hexo 웹사이트에서 해당 폴더에 있는 이미지가 사용되는 것을 확인할 수 있습니다.

특정 폴더에 있는 정적 이미지를 가져오려면, 이미지 폴더를 생성하고 이미지를 해당 폴더에 추가한 후, Markdown 파일에서 이미지의 상대 경로를 지정하여 사용하면 됩니다. 이를 통해 원하는 폴더에 있는 이미지를 손쉽게 Hexo 웹사이트에 포함시킬 수 있습니다.

hexo에서 A메뉴를 선택하면 포스트 중에서 A라는 포스트만 가져오는 방법은?

ChatGPT:

  • Hexo에서 특정 메뉴를 선택하면 해당 메뉴에 속하는 포스트만 가져오는 방법은 Hexo의 데이터 필터링 기능을 사용하는 것이 좋습니다. Hexo에서는 데이터를 필터링하는데 사용할 수 있는 다양한 방법이 있습니다. 가장 간단하고 일반적인 방법은 Front Matter를 이용하여 포스트에 메뉴 정보를 추가하는 것입니다.

다음은 A라는 메뉴를 선택하면 A라는 메뉴에 속하는 포스트만 가져오는 방법의 예시입니다:

  1. Front Matter에 메뉴 정보 추가:
    A 메뉴에 속하는 포스트들에게 Front Matter를 이용하여 메뉴 정보를 추가합니다. 각 포스트의 Markdown 파일에서 Front Matter 영역에 menu 항목을 추가합니다.

예를 들어, A 메뉴에 속하는 포스트에 menu: A라는 정보를 추가하려면 아래와 같이 작성합니다:

1
2
3
4
5
6

---
title: A 포스트
date: 2023-08-06
menu: A
---

위와 같이 menu 항목에 메뉴 이름을 지정해주면 해당 포스트가 A 메뉴에 속하게 됩니다.

  1. A 메뉴에서 포스트 필터링:
    A 메뉴에서 A에 해당하는 포스트들만 가져오려면 해당 메뉴를 표시하는 템플릿 파일에서 필터링 기능을 사용하여 포스트를 선택합니다. 대부분의 테마에서는 메뉴에 해당하는 템플릿 파일이 _config.yml 파일에 지정된 대로 사용됩니다.

예를 들어, A 메뉴를 표시하는 menu_A.ejs라는 템플릿 파일이 있다면, 해당 파일에서 A 메뉴에 속하는 포스트를 가져오기 위해 다음과 같이 필터링 기능을 사용합니다:

1
2
3
4
5
6

<% var postsInMenuA = page.posts.filter(post => post.menu === 'A'); %>

<% postsInMenuA.forEach(post => { %>
<!-- 포스트를 템플릿에 표시하는 코드 -->
<% }); %>

위 코드에서는 page.posts.filter(post => post.menu === 'A')로 A 메뉴에 속하는 포스트들만 필터링하여 postsInMenuA라는 변수에 저장합니다. 그리고 postsInMenuA.forEach(...)로 필터링된 포스트들을 순회하며 템플릿에 표시하는 코드를 작성합니다.

이렇게 필터링 기능을 사용하여 A 메뉴에 속하는 포스트들만 템플릿에 표시하면, A 메뉴를 선택하면 해당 메뉴에 속하는 포스트만 가져올 수 있습니다. 필요에 따라 테마의 템플릿 파일을 커스터마이징하여 원하는 메뉴별로 포스트를 필터링할 수 있습니다.

hexo post에서 category 지정법

ChatGPT:

  • Hexo에서 포스트(Post)를 작성할 때 카테고리(Category)를 지정하려면 Front Matter를 사용하여 포스트에 카테고리 정보를 추가하면 됩니다. Front Matter는 Markdown 파일의 상단에 위치하며, YAML 또는 JSON 형식으로 작성됩니다.

카테고리를 지정하는 방법은 다음과 같습니다:

  1. Front Matter에 카테고리 정보 추가:
    포스트를 작성하는 Markdown 파일에서 Front Matter 영역에 categories 항목을 추가합니다. categories 항목에는 해당 포스트의 카테고리를 지정하는데 사용됩니다. 단일 카테고리 또는 다중 카테고리를 지정할 수 있습니다.

단일 카테고리를 지정하는 경우:

1
2
3
4
5
6
7
8

---
title: 포스트 제목
date: 2023-08-06
categories: 카테고리명
---

포스트 내용...

다중 카테고리를 지정하는 경우:

1
2
3
4
5
6
7
8
9
10

---
title: 포스트 제목
date: 2023-08-06
categories:
- 카테고리1
- 카테고리2
---

포스트 내용...
  1. Hexo 빌드:
    카테고리 정보를 추가한 후, Hexo를 다시 빌드하여 변경 사항이 반영되도록 합니다. 터미널 또는 명령 프롬프트에서 프로젝트 디렉토리로 이동한 다음 다음 명령어를 실행합니다:
1
2
3

hexo clean # 기존 정적 파일들을 삭제
hexo generate # 새로운 정적 파일들 생성

변경한 카테고리 정보가 성공적으로 적용되면, Hexo 웹사이트에서 해당 포스트가 지정한 카테고리에 속하는 것을 확인할 수 있습니다.

이제 Front Matter를 이용하여 포스트에 카테고리 정보를 추가할 수 있으며, 카테고리별로 포스트를 구분하여 웹사이트를 조직화할 수 있습니다.