Jekyll
С помощью Jekyll (генератор статических сайтов) и GitHub Pages (хостинг, на котором работает Jekyll) можно создать бесплатный статический сайт для своего блога или личного сайта. Лимит размера - 1 ГБ.
Для создания сайта необходимо зарегистрироваться на GitHub:
Для создания сайта необходимо установить:
Git - https://git-scm.com/download/win
Jekyll - https://jekyllrb.com/docs/installation/windows/
Создание сайта
Вместо username использую твой username на GitHub.
Отправляйся в командную строку:
Win+R cmd
git init username.github.io
cd username.github.io
git checkout --orphan main
jekyll new --skip-bundle .
bundle install
git add .
git commit -m "first commit"
git remote add origin https://github.com/username/username.github.io.git
git push -u origin main
Твой сайт будет расположен по адресу https://username.github.io/
Информация на сайте
В файле _config.yml заполняешь title, author, email, url, description (его можно удалить). В файле about.markdown прописываешь описание сайта.
Создание страницы
Создай .md файл в папке сайта. Например, page.md. Тогда на твоём сайте появится страничка по адресу https://username.github.io/page. Можешь поместить файл в папку folder. Тогда на твоём сайте появится страничка по адресу https://username.github.io/folder/page.
Создание поста
https://jekyllrb.com/docs/posts/
Форматирование
1) Жирный текст - **жирный текст**
2) Курсив - *курсив*
3) Заглавие (в начале текста):
---
comments: true
title: Заглавие
---
4) Заголовок - # текст заголовка
5) Подзаголовок - #### текст подзаголовка
6) Новый абзац - пустая строка
7) Выделение ссылки - <ссылка>
8) Ссылка - [текст](ссылка)
9) Ссылка на страницу сайта: [текст](/папка/страница)
10) Ссылка туда и обратно:
текст<a href="#note" id="note-back">†</a>
<a href="#note-back" id="note">†</a> текст примечания
11) Ссылка на место в тексте:
[Place](#place)
<a id="place"></a>
12) Содержание:
#### Содержание
[Введение](#introduction)
<a id="introduction"></a>
#### Введение
13) Разрыв строки - <br>
14) Пустая строка (двойной разрыв строки) - <br><br>
15) Примечание:
текст[^1] текст[^2]
[^1]: текст примечания
текст примечания
[^2]: текст примечания
16) Цитата:
> цитата
>
> продолжение цитаты
17) Маленький текст - <sub>текст</sub>
https://www.markdownguide.org/basic-syntax/
Добавление картинки
Допустим, ты положил картинку image.png в папку images.
Как разместить картинку на странице:
![Описание картинки](/images/image.png)
В центре:
{:refdef: style="text-align: center;"}
![Описание картинки](/images/image.png)
{: refdef}
Со ссылкой:
{:refdef: style="text-align: center;"}
[![Описание картинки](/images/image.png)](ссылка)
{: refdef}
Добавление аудио
https://stackoverflow.com/questions/63701944/how-to-embed-audio-into-a-jekyll-blog
Добавление видео
https://github.com/nathancy/jekyll-embed-video
Добавление иконки сайта
https://medium.com/@xiang_zhou/how-to-add-a-favicon-to-your-jekyll-site-2ac2179cc2ed
Обновление сайта
Win+R cmd
cd username.github.io
git add .
git commit -m "new commit"
git push
Можно создать .bat файл и поместить в него эти команды. Тогда коммит можно сделать двумя кликами. Чтобы командная строка не закрывалась сразу после выполнения команд, добавь команду pause.
Запуск сайта локально
Во избежание ошибки, необходимо добавить webrick в Gemfile:
cd username.github.io
bundle add webrick
Запуск сайта:
cd username.github.io
bundle exec jekyll serve
Проходишь по выданному адресу.
Фильтрация зоны навигации (правый верхний угол)
Прописываешь в _config.yml:
header_pages:
-about.markdown
Изменение размера заглавия
Заходишь в папку minima. На Windows она находится где-то здесь:
C:\Ruby32-x64\lib\ruby\gems\3.2.0\gems\minima-2.5.1
Заходишь в папку _layouts. Копируешь (Ctrl+C) page.html.
Создаёшь папку _layouts в username.github.io. Вставляешь (Ctrl+V). Редактируешь page.html с помощью Notepad++. Удаляешь
class="post-title"
Указание источника в постах
Иногда я “репощу” некоторые тексты в моих постах. Я предпочитаю указывать источник текста перед текстом. Дефолтный макет постов помещает заглавие наверху, так что я скопировал post.html в папку _layout и удалил кусок кода, который создаёт заглавие.
Markdown файл таких постов выглядит так:
---
layout: post
tag: Reposts
comments: true
title: Заглавие текста
---
Источник: [Название источника](ссылка на источник)
<br><br>
# Заглавие текста
Комментарии
https://help.disqus.com/en/articles/1935528-jekyll-installation-instructions
Подчёркивания и заметки на полях
Есть способ воспроизвести подчёркивания и заметки на полях как в бумажных книгах в постах.
I was listening to <span class="underlining">NPR</span> the other day. <span class="marginalia">I listen to it in the car.</span>
Добавь этот скрипт в post.html:
<style>
.post-content {
position: relative;
max-width: 700px;
margin: 0 auto;
}
.marginalia {
position: absolute;
right: -250px;
width: 200px;
padding: 10px;
background-color: #f8f9fa;
border-left: 3px solid #dee2e6;
border-radius: 4px;
font-size: 0.9em;
color: #000000;
opacity: 0;
transform: translateX(20px);
transition: all 0.3s ease;
margin-top: -10px;
}
.marginalia.visible {
opacity: 1;
transform: translateX(0);
}
.toggle-annotations {
position: fixed;
top: 20px;
right: 20px;
padding: 8px 16px;
background-color: #007bff;
color: white;
border: none;
border-radius: 4px;
cursor: pointer;
transition: background-color 0.2s;
z-index: 1000;
}
.toggle-annotations:hover {
background-color: #0056b3;
}
.underlining {
text-decoration: none;
transition: text-decoration 0.3s ease;
}
.underlining.visible {
text-decoration: underline;
text-decoration-color: blue;
text-decoration-thickness: 3px;
}
@media (max-width: 1200px) {
.toggle-annotations {
display: none;
}
}
</style>
<script>
window.addEventListener('DOMContentLoaded', function() {
const marginalia = document.querySelectorAll('.marginalia');
const button = document.getElementById('annotationsButton');
if (marginalia.length > 0) {
button.style.display = 'block';
}
});
let annotationsVisible = false;
function toggleAnnotations() {
const marginalia = document.querySelectorAll('.marginalia');
const underlinedText = document.querySelectorAll('.underlining');
const button = document.querySelector('.toggle-annotations');
annotationsVisible = !annotationsVisible;
marginalia.forEach(note => {
note.classList.toggle('visible', annotationsVisible);
});
underlinedText.forEach(text => {
text.classList.toggle('visible', annotationsVisible);
});
button.textContent = annotationsVisible ? 'Hide Annotations' : 'Show Annotations';
}
</script>