Chomu's Blog.

>

Posts

GitHub

Jekyll을 사용한 GitHub Pages 블로그 카테고리화

목차

사이드바

사이드바는 _includes/nav.html에서 설정합니다. HydeJack으로 테마를 적용한 제 블로그는 nav.html 파일은 기본적으로 이렇게 생겼었습니다.

<span class="sr-only">{{ site.data.strings.navigation | default:"Navigation" }}{{ site.data.strings.colon | default:":" }}</span>
<!--
  `site.data.strings.변수_명`는 `_data/strings.yaml` 파일에서 `변수_명` 값을 가져옵니다. `_data`는 상수(constant)를 저장하는 경로이며 그 중에서도 `strings.yaml` 파일은 문자열로 상수를 저장하는 파일입니다.
-->
<ul>
  {% assign pages = site.pages | where: "menu", true %}
  {% assign documents = site.documents | where: "menu", true %}
  {% assign nodes = pages | concat: documents | sort: "order" %}
  <!--
    `assign`: 변수를 지정하는 태그입니다.
    `where`: 배열의 원소의 요소 값을 기준으로 거르는 필터입니다.
    `comment`, `endcomment`: 주석으로 처리하는 태그입니다.
  -->
  {% for node in nodes %}
  <!-- `nodes` 배열에서 원소들을 뽑아 `node` 에 지정하는 for 문입니다. 파이썬과 비슷한 모습을 가지고 있습니다. -->
    {% unless node.redirect_to %}
    <!-- `unless`: if의 반대입니다. `if not < 표현식 >`으로 생각하면 됩니다. -->
      <li>
        <a
          {% if forloop.first %}id="_navigation"{% endif %}
          <!-- forloop: for 루프에 관한 정보를 담고 있습니다. -->
          href="{{ node.url | relative_url }}"
          <!-- relative_url: 상대 주소로 만들어주는 필터입니다. -->
          class="sidebar-nav-item{% if page.url contains node.url %} active{% endif %}"
          <!-- 링크 중 현재 페이지가 해당 페이지이면 `active` 클래스를 추가합니다. -->
          {% if path.rel %}rel="{{ node.rel }}"{% endif %}
          >
          {{ node.title }}
        </a>
      </li>
    {% else %}
      <li>
        <a href="{{ node.redirect_to }}" class="sidebar-nav-item external" >{{ node.title }}</a>
        <!-- 리다이렉트 페이지가 링크되어 있으면 해당 링크로 넘겨줍니다. -->
      </li>
    {% endunless %}
  {% endfor %}
</ul>

부가 설명:

  • site 변수는 사이트 정보(공식 문서 하단에 더 자세히 나와있습니다.)와 _config.yml 파일의 환경 설정 정보라고 합니다. 자세한 정보는 Jeykyll 공식 한국어 사이트의 변수 문서를 참고하세요.
  • where 필터는 where: < 찾는_키 > < 찾는_값 >은 파이프로 건너온 값 중 찾는_키의 값이 찾는_값인 값을 추립니다. 예를 들어서 상기한 코드의 {% assign pages = site.pages | where: "menu", true %} 같은 경우에는 먼저 site.pages(사이트 내의 모든 페이지에 대한 정보를 가진 배열)를 가져와서 이를 where 필터로 넘깁니다. where는 그 중에 menu의 값이 true인 값들을 필터링합니다. 마지막으로 assign 태그가 그 배열을 pages 변수에 할당합니다. 파이썬의 pages = [page for page in site.pages if page.menu == True], JS의 const pages = site.pages.filter(page => page.menu === True) 정도의 코드로 생각하시면 될 것 같습니다. 이때 페이지의 정보는 머리말로 지정할 수 있습니다. 자세한 정보는 Liquid의 filters/where 문서를 참고하세요.
  • forloop 객체는 부모 for 루프에 대한 정보를 담고 있습니다. 예를 들어 forloop.first는 현재가 첫번째 반복인지를 담고 있습니다. 자세한 정보는 Shopify 개발 블로그의 Liquid/objects/forloop 문서를 참고하세요.

따라서 사이드 바에 카테고리를 넣기 위해서는

  1. 사이드 바 수정하기
  2. 카테고리 별 페이지 만들기

하면 될 것이라고 생각했습니다.

사이드바에서 전체 카테고리 표출하도록 만들기

_includes/nav.html 을 다음과 같이 수정했습니다.

<!-- 생략 -->
<ul>
  {% for category in site.categories %}
    <!-- site.categories 에는 사이트 내 페이지들의 카테고리 별 페이지 목록이 담겨있습니다. -->
    <li><a href="/category/{{ category | first }}"><strong>{{ category | first }}</strong></a></li>
    <!-- {{ category | first }} 는 카테고리의 이름이 들어있습니다. -->
  {% endfor %}
</ul>
<!-- 생략 -->

원래 /category/ 대신 {{ category.url }}으로 사용할 수 있으나(_config.yml에서 수정 가능) 알 수 없는 이유로 종종 /category/으로 연결되지 않는 오류가 발생하여 직접 작성하였습니다.

카테고리 페이지 만들기

레이아웃 만들기

카테고리 별 페이지를 일정하게 만들기 위해 레이아웃을 먼저 지정해줄 것입니다. _layouts 폴더에 자주 쓰는 형식을 레이아웃으로 저장할 수 있습니다. _layouts 폴더 내에 다음과 같은 내용의 category.html를 추가합니다. 지킬(Jekyll) 블로그 카테고리(category) 만들기를 참고했습니다.

---
layout: default
---
{% assign category = page.category | default: page.title %}
<!-- 현재 페이지의 `category` 요소를 가져옵니다. 없다면 페이지 제목을 가져옵니다. 이를 `category` 변수에 할당합니다. -->
<ul>
  {% for post in site.categories[category] %}
  <!-- 사이트에서 `category` 카테고리인 페이지들을 가져와 `post`에 할당하는 for문 입니다. -->
    <li>
      <a href="{{ post.url }}"> {{ post.title }} </a>
      <!-- `post` 제목을 표시하고 해당 글의 URL을 링크합니다. -->
      <small>{{ post.date | date_to_string }}</small>
      <!-- 글이 쓰여진 날짜를 문자열로 바꿔 표시합니다. -->
    </li>
  {% endfor %}
</ul>

부가설명

이후 머리말에 layout: category을 적어주면 해당 레이아웃이 적용됩니다.

카테고리 별 페이지 만들기

먼저 category/ 경로를 만든 뒤, 해당 경로 내에 카테고리 별 이름을 가진 markdown 파일을 만들어 줍니다. 그 후, 레이아웃을 category으로 지정하고, 카테고리나 페이지 제목을 해당 카테고리 이름으로 지정합니다. 예를 들어서, Jekyll이라는 카테고리를 만들었을 경우, category/Jekyll.md 파일을 만든 뒤, 내용을 다음과 같이 지정합니다.

---
layout: category
category: Jekyll
title: Jekyll
---

상기했듯, 카테고리와 제목 둘 중에 하나만 지정할 수 있습니다. 왜냐하면, 먼저 페이지의 카테고리를 가져온 뒤, 카테고리가 없다면 제목을 가져오도록 만들었기 때문입니다.

전체 카테고리 페이지 만들기

추가로 모든 카테고리를 볼 수 있는 페이지를 만들겠습니다. category/index.md 파일을 만든 뒤 _includes/nav.html에 수정했던 내용과

---
layout: default
title: Category
---
<ul>
  {% for category in site.categories %}
    <li><a href="/category/{{ category | first }}"><strong>{{ category | first }}</strong></a></li>
  {% endfor %}
</ul>

금방 눈치채시겠지만 _includes/nav.html와 비슷한 내용입니다. 해당 페이지를 만든 뒤, 사이드바에서 전체 카테고리 페이지와 날짜별 포스트를 볼 수 있도록 _includes/nav.html에 다음과 같은 내용을 추가했습니다.

<ul>
  <li><a href="/category"><strong>Category</strong></a></li>
  <li><a href="/posts"><strong>Posts</strong></a></li>
</ul>

출처 및 참고