티스토리에서 간단하게 자동 목차 만들기

반응형

[목차]
긴 글을 읽다 보면 '아, 이 내용이 어디 있었더라?' 하며 스크롤을 위아래로 움직여본 경험, 다들 있으시죠?
특히 정보성 글이나 튜토리얼의 경우 목차의 부재는 독자들에게 큰 불편함을 줄 수 있습니다.
또한, 목차는 독자의 편의성을 높이는 것은 물론, 글의 전문성을 한층 업그레이드해주고, 검색엔진 최적화(SEO)에도 도움이 되죠.
그래서 오늘은 티스토리 블로그에서 목차가 왜 필요한지, 그리고 어떻게 삽입할 수 있는지 자세히 알아보도록 하겠습니다.
특히 블로그를 시작하신 지 얼마 안 되신 분들이라면, 이 글이 큰 도움이 될 거예요.

1단계 : 자동 목차 스크립트 파일 생성

목차 생성을 위한 JavaScript 파일을 만들고 이를 HTML 코드에 포함시켜야 하는데요,
우선,  JavaScript 파일은 아래 첨부파일을 다운받으면 됩니다.
 

<자동 목차 스크립트 파일 다운로드>

toc.js
0.00MB

 
파일 내용은 아래와 같은데요, 게시글에 제목 스타일(h2, h3, h4 등)이 적용된 곳을 목차로 만들어 줍니다.
원하는 스타일만 목차로 설정하고자 한다면
코드 중간 부분에 있는 " querySelectorAll('h1, h2, h3, h4')); "을 수정하여 저장합니다.

document.addEventListener('DOMContentLoaded', function() {
    try {
        const contentContainer = document.querySelector('.contents_style');
        const tocExists = document.getElementById('toc-ym');

        if (contentContainer && !tocExists) {
            htmlTableOfContents();
        } else {
            return false;
        }
    } catch (e) {
        console.log('Error creating Table of Contents: ', e);
    }
});

function htmlTableOfContents(container = document) {
    const tocDiv = document.createElement('div');
    tocDiv.setAttribute('id', 'toc-ym');

    const contentContainer = document.querySelector('.contents_style');
    const xpathResult = document.evaluate(
        "//p[contains(text(),'[목차]')]", 
        document, 
        null, 
        XPathResult.FIRST_ORDERED_NODE_TYPE, 
        null
    ).singleNodeValue;

    let insertBeforeNode;
    if (xpathResult) {
        insertBeforeNode = xpathResult;
        insertBeforeNode.innerHTML = '';
        insertBeforeNode.appendChild(tocDiv);
    } else {
        insertBeforeNode = contentContainer.firstElementChild;
        if (insertBeforeNode.classList.contains('tt_adsense_top') || insertBeforeNode.classList.contains('another_category')) {
            contentContainer.insertBefore(tocDiv, insertBeforeNode.nextSibling);
        } else {
            insertBeforeNode.parentNode.insertBefore(tocDiv, insertBeforeNode);
        }
    }

    const tocElement = document.getElementById('toc-ym');
    const headers = [].slice.call(contentContainer.querySelectorAll('h1, h2, h3, h4'));
    const filteredHeaders = headers.filter(header => {
        return header.textContent.trim() !== '' &&
            !header.classList.contains('revenue_unit_wrap') &&
            !header.parentNode.classList.contains('revenue_unit_wrap');
    });

    filteredHeaders.forEach((header, index) => {
        let headerId = `toc-${index}`;
        if (header.hasAttribute('id')) {
            headerId = header.getAttribute('id');
        } else {
            header.setAttribute('id', headerId);
        }

        const anchor = container.createElement('a');
        anchor.setAttribute('href', `#${headerId}`);
        anchor.textContent = `• ${header.textContent.trim()}`;

        const div = container.createElement('div');
        div.setAttribute('class', header.tagName.toLowerCase());
        div.appendChild(anchor);
        tocElement.appendChild(div);
    });

    const tocStyle = `
    #toc-ym div.h1 { margin-left: 0em   }
    #toc-ym div.h2 { margin-left: 1em   }
    #toc-ym div.h3 { margin-left: 6em   }

    #toc-ym {
        margin: 30px 0px 30px 0px;
        padding: 20px 20px 10px 15px;
        border: 1px solid #dadada;
        background-color: #ffffff;
    }
    #toc-ym::before {
        content: "목차";
        display: block;
        width: 120px;
        background-color: rgb(255, 255, 255);
        text-align: center;
        font-size: 17px;
        font-weight: bold;
        margin: -40px auto 0px;
        padding: 5px 0px;
        border-width: 1px;
        border-style: solid;
        border-color: rgb(218, 218, 218);
        border-image: initial;
    }
    #toc-ym div {
        margin: 5px 0px;
    }
    #toc-ym div:first-child {
        margin-top: 15px;
    }
    #toc-ym div:last-child {
        margin-bottom: 15px;
    }
    #toc-ym div a {
        text-decoration: none;
        color: #337ab7;
        transition: all ease 0.2s;
    }
    #toc-ym div a:hover {
        color: #333333;
        background-color: #ecc7ff;
    }
    `;

    const styleElement = document.createElement('style');
    styleElement.innerHTML = tocStyle;
    contentContainer.insertBefore(styleElement, insertBeforeNode);
}

2단계 : 티스토리에 스크립트 파일 업로드

티스토리 관리자 모드로 들어가서 블로그관리 홈 -> 꾸미기 -> 스킨 편집 -> html 편집으로 들어갑니다.

 
 
'파일업로드' > '추가' 버튼을 클릭하여 미리 다운받은 'toc.js' 파일을 업로드 합니다.

3단계 : 티스토리 html 코드에 자동 목차 스크립트 반영

티스토리 블로그의 HTML 편집기에 접근하여 toc.js 파일을 포함하는 스크립트 태그를 추가한 후 '적용' 버튼을 눌러줘야 반영이 됩니다.

<script src="./images/toc.js"></script>

추가적으로 목차를 삽입하고 싶은 위치가 있다면 "[목차]"라는 텍스트를 추가하면 그 위치에 자동으로 목차가 생성됩니다.

반응형