본문 바로가기
Computer Science/Web

github.io 사이트 설정 - 2

by zxcvber 2020. 1. 10.

Originally written on January 02, 2020

 

새해를 기념하여 글을 좀 더 열심히 작성하자는 생각에 이 사이트를 다시 방문했다.
지난번에 남겨둔 해결해야 할 문제들을 다시 살펴보았고, 해결 할 수 있는 부분은 해결을 시도했다.

검색 결과가 발생하지 않는 문제

이 페이지를 검색하려고 검색에서 사이트 로 검색했는데 결과가 없음.
왠지 모르겠는데 다시 해보니까 아무 문제 없이 된다. 그런데 footer 쪽에 있는 related posts 에 들어있는 텍스트도 (즉, 해당 포스트에는 직접적으로 포함되지 않는 내용) 감지 되어 검색 결과에 같이 등장한다. 이게 뭐지?

상단 메뉴 별 pagination 적용 문제

상단 메뉴 선택시 해당 토픽의 최근 포스트를 보여줄 때 포스트 개수 제한 없이 모두 보여주어 스압 발생. (paginator 적용 안되어 있음)
사용하는 pluginjekyll-paginate 를 더 이상 사용하지 않기로 하고, jekyll-paginate-v2 를 사용하기로 했다.

config.yml 에 다음과 같은 내용을 추가했다.

plugins:
    - jekyll-paginate-v2

pagination:
    enabled: true
    per_page: 5     # 5개씩 보여주기
    limit: 0
    sort_field: "date"
    sort_reverse: true
    title: ':title'     # 타이틀 형식

그리고 Gemfile 에는 다음 내용을 추가했다.

group :jekyll_plugins do
    gem "jekyll-paginate-v2"

당연히 bundle install 명령어를 한 번 입력해 줘야 하고, index.html 을 다음과 같이 변경했다.

---
layout: home
author_profile: true
pagination:
    enabled: true
    per_page: 5
---

{% for post in paginator.posts %}
  {% include archive-single.html %}
{% endfor %}

{% if paginator.total_pages > 1 %}
    <div class="pagination">
        {% if paginator.previous_page %}
            <a href="{{ paginator.previous_page_path | prepend: site.baseurl | replace: '//', '/' }}">&laquo; Prev</a>
        {% else %}
            <span>&laquo; Prev</span>
        {% endif %}

        {% for page in (1..paginator.total_pages) %}
            {% if page == paginator.page %}
                <em>{{ page }}</em>

            {% elsif page == 1 %} 
                <a href="{{ '/index.html' | prepend: site.baseurl }}">{{ page }}</a>
            {% else %}
                <a href="{{ site.paginate_path | prepend: '/' | prepend: site.baseurl | replace: '//', '/' | replace: ':num', page }}">{{ page }}</a>     
            {% endif %}
        {% endfor %}

        {% if paginator.next_page %}
            <a href="{{ paginator.next_page_path | prepend: site.baseurl | replace: '//', '/' }}">Next &raquo;</a>
        {% else %}
            <span>Next &raquo;</span>
        {% endif %}
    </div>
{% endif %}

일단 당장은 디자인이 좀 구리다 (…)
Bootstrap 이라도 이용해서 다시 고칠 생각을 하고 있다.

위와 같은 방식을 이용해서 category 별로 저 부분을 다 작성해서 넣어주면 pagination 이 잘 될 것이라고 기대하고 있다.

또 다른 문제를 하나 발견했는데…

Category 가 많아지면 url 이 길어지는 문제

인지하지 못하고 있었는데, category 를 막 집어넣었더니 카테고리들이 / 로 분리되어 전부 url 에 포함되는 것을 확인할 수 있었다. 일단은 임시 방편으로, permalink 를 :path 로만 해두었다.

permalink: /:path/

원하는 것은, /대분류/:title/ 인데, collection 을 사용하면 될 것 같지만, 아직도 collection 은 잘 모르겠다.

아니면 태그를 잘 활용하는 것도 방법이 되지 않을까 고민하고 있다.

TODO

  • 상단의 Category 탭에서는 paginator 를 어떻게 적용해야 할지 전혀 모르겠다. 차라리 tag 를 도입해서 tag 가 같은 문서 끼리만 볼 수 있도록 구현을 하는 것이 방법일 것 같다.
  • _includes, _layouts 에 뭐가 굉장히 많다. liquid syntax 를 익히고, template 들을 분석해서 사이트를 보다 더 다채롭게 사용할 수 있으면 좋겠다.

추가 내용

변경 사항들을 repo 에 모두 push 했는데, pagination 이 작동하지 않는다. 전체 recent post, CSE 카테고리 recent post 가 전부 보이지 않는다.

일단 의도대로 페이지가 동작하지 않는 이유는 unsupported plugin 을 사용했기 때문이다. Supported plugin 들의 목록은 여기 에서 확인할 수 있었다. jekyll-paginate-v2 는 목록에 없다. 그리고 Github Pages Documentation 을 확인해 보니

GitHub Pages cannot build sites using unsupported plugins. If you want to use unsupported plugins, generate your site locally and then push your site’s static files to GitHub.

라고 한다. 이제 여기 적혀있는 대로 하면 되겠지?

태그별 정리

몇몇 포스트에 태그를 추가하여 /tags/ 로 들어가면 태그 별로 정리되어 있는 글 목록을 볼 수는 있다.

---
title: "Posts by Tag"
permalink: /tags/
layout: tags
author_profile: true
---

하지만 마찬가지로 아직도 글의 개수가 많아질 경우에는 pagination 이 안된다는 문제가 남아있다. 이걸 정말 해결하고 싶다면, 태그별로 페이지를 만들어 주면 되긴 하는데, 새로운 태그가 생길 경우에 그 태그에 해당하는 포스트만 모아둔 페이지를 매번 만들어 줘야 한다는 불편함이 존재하게 된다. 아니면 이대로 두는 것도 방법이다 …

'Computer Science > Web' 카테고리의 다른 글

1년 뒤 다시 찾아본 인터넷 편지 사이트  (4) 2021.05.03
육군훈련소에서 인터넷 편지 편하게 받기  (0) 2020.06.13
Docker 기초  (0) 2020.02.27
Tistory 이주  (0) 2020.01.10
github.io 사이트 설정  (0) 2020.01.10

댓글