--- language: markdown contributors: - ["Dan Turkel", "http://danturkel.com/"] - ["Jacob Ward", "http://github.com/JacobCWard/"] translators: - ["Pirogov Alexey", "http://twitter.com/alex_pir"] - ["Andre Polykanine", "https://github.com/Oire"] filename: markdown-ru.md lang: ru-ru --- Язык разметки Markdown создан Джоном Грубером (англ. John Gruber) в 2004 году. Авторы задавались целью создать максимально удобочитаемый и удобный в публикации облегчённый язык разметки, пригодный для последующего преобразования в HTML (а также и в другие форматы). Также реализации Markdown варьируют в зависимости от парсера. В этом руководстве будет указано, какие функции универсальны для языка, а какие зависят от конкретного парсера. - [HTML-элементы](#html-elements) - [Заголовки](#headings) - [Простейшая стилизация текста](#simple-text-styles) - [Абзацы](#paragraphs) - [Списки](#lists) - [Блоки кода](#code-blocks) - [Горизонтальный разделитель](#horizontal-rule) - [Ссылки](#links) - [Изображения](#images) - [Разное](#miscellany) ## HTML-элементы Markdown является надмножеством HTML, поэтому любой HTML-файл является корректным документом Markdown. ```md <!-- Это позволяет использовать напрямую любые элементы HTML-разметки, такие, например, как этот комментарий. Встроенные в документ HTML-элементы не затрагиваются парсером Markdown и попадают в итоговый HTML без изменений. Однако следует понимать, что эта же особенность не позволяет использовать разметку Markdown внутри HTML-элементов --> ``` ## Заголовки HTML-элементы от <h1> до <h6> размечаются очень просто: текст, который должен стать заголовком, предваряется соответствующим количеством символов "#": ```md # Это заголовок h1 ## Это заголовок h2 ### Это заголовок h3 #### Это заголовок h4 ##### Это заголовок h5 ###### Это заголовок h6 ``` Markdown позволяет размечать заголовки <h1> и <h2> ещё одним способом: ```md Это заголовок h1 ================ А это заголовок h2 ------------------ ``` ## Простейшая стилизация текста Текст легко сделать полужирным и/или курсивным: ```md *Этот текст будет выведен курсивом.* _Так же, как этот._ **А этот текст будет полужирным.** __И этот тоже.__ ***Полужирный курсив.*** **_И тут!_** *__И даже здесь!__* ``` В Github Flavored Markdown, стандарте, который используется в Github, текст также можно сделать зачёркнутым: ```md ~~Зачёркнутый текст.~~ ``` ## Абзацы Абзацами являются любые строки, следующие друг за другом. Разделяются же абзацы одной или несколькими пустыми строками: ```md Это абзац. Я печатаю в абзаце, разве это не прикольно? А тут уже абзац №2. Эта строка всё ещё относится к абзацу №2! О, а вот это уже абзац №3! ``` Для вставки принудительных переносов можно завершить абзац двумя дополнительными пробелами: ```md Эта строка завершается двумя пробелами (выделите, чтобы увидеть!). Над этой строкой есть <br />! ``` Цитаты размечаются с помощью символа «>»: ```md > Это цитата. В цитатах можно > принудительно переносить строки, вставляя «>» в начало каждой следующей строки. А можно просто оставлять их достаточно длинными, и такие длинные строки будут перенесены автоматически. > Разницы между этими двумя подходами к переносу строк нет, коль скоро > каждая строка начинается с символа «>» > А ещё цитаты могут быть многоуровневыми: >> как здесь >>> и здесь :) > Неплохо? ``` ## Списки Маркированные списки размечаются вставкой в начало каждого элемента одного из символов «*», «+» или «-»: (символ должен быть одним и тем же для всех элементов) ```md * Список, * Размеченный * Звёздочками либо + Список, + Размеченный + Плюсами либо - Список, - Размеченный - Дефисами ``` В нумерованных списках каждая строка начинается с числа и точки вслед за ним: ```md 1. Первый элемент 2. Второй элемент 3. Третий элемент ``` Заметьте, нумеровать элементы корректно необязательно. Достаточно указать любое число в начале каждого элемента, и парсер пронумерует элементы сам! Правда, злоупотреблять этим не стоит :) ```md 1. Первый элемент 1. Второй элемент 1. Третий элемент ``` (Этот список будет отображён так же, как и предыдущий!) Списки могут быть вложенными: ```md 1. Введение 2. Начало работы 3. Примеры использования * Простые * Сложные 4. Заключение ``` Можно даже делать списки задач. Блок ниже создаёт HTML-флажки. ```md Для отметки флажка используйте «x» - [ ] Первая задача - [ ] Вторая задача Этот флажок ниже будет отмечен - [x] Задача была завершена ``` ## Блоки кода Фрагменты исходного кода (обычно отмечаемые тегом `<code>`) выделяются просто: каждая строка блока должна иметь отступ в четыре пробела либо в один символ табуляции. ```md Это код, причём многострочный ``` Вы также можете делать дополнительные отступы, добавляя символы табуляции или по четыре пробела: ```md my_array.each do |item| puts item end ``` Иногда бывает нужно вставить фрагмент кода прямо в строку текста, не выделяя код в блок. Для этого фрагменты кода нужно обрамлять символами «`»: ```md Ваня даже не знал, что делает функция `go_to()`! ``` В Github Flavored Markdown для блоков кода можно использовать специальный синтаксис: <pre> <code class="highlight">```ruby def foobar puts "Привет, мир!" end ```</code></pre> Во фрагменте, приведённом выше, отступ не требуется. Кроме того, Github подсветит синтаксис языка, указанного после \`\`\` ## Горизонтальный разделитель Разделители (`<hr>`) добавляются вставкой строки из трёх и более (одинаковых) символов «*» или «-», с пробелами или без них: ```md *** --- - - - **************** ``` ## Ссылки Одной из сильных сторон Markdown можно смело считать то, как просто размечаются гиперссылки. Для создания ссылки укажите текст ссылки, заключив его в квадратные скобки, и сразу после — URL-адрес, заключенный в круглые ```md [Ссылка!](http://test.com/) ``` Также для ссылки можно указать всплывающую подсказку (`title`), используя кавычки внутри круглых скобок: ```md [Ссылка!](http://test.com/ "Ссылка на Test.com") ``` Относительные пути тоже возможны: ```md [Перейти к музыке](/music/). ``` Markdown также позволяет размечать ссылку в виде сноски: <pre><code class="highlight">[<span class="nv">Щёлкните эту ссылку</span>][<span class="ss">link1</span>] для подробной информации! [<span class="nv">Также посмотрите эту ссылку,</span>][<span class="ss">foobar</span>] если хотите. [<span class="nv">link1</span>]: <span class="sx">http://test.com/</span> <span class="nn">"Круто!"</span> [<span class="nv">foobar</span>]: <span class="sx">http://foobar.biz/</span> <span class="nn">"Нормально!"</span></code></pre> `Title` также может быть в одинарных кавычках или круглых скобках, а также отсутствовать вовсе. Ссылки на сноски могут быть в любом месте документа, а идентификаторы могут быть какими угодно, лишь бы они были уникальными. Существует также неявное именование, когда ссылка является идентификатором. <pre><code class="highlight">[<span class="nv">Это</span>][] ссылка. [<span class="nv">это</span>]: <span class="sx">http://thisisalink.com/</span></code></pre> Правда, эта возможность не очень распространена. ## Изображения Разметка изображений очень похожа на разметку ссылок. Нужно всего лишь добавить перед ссылкой восклицательный знак! ```md ![Альтернативный текст для изображения](http://imgur.com/myimage.jpg "Подсказка") ``` Изображения тоже могут быть оформлены, как сноски. <pre><code class="highlight">![<span class="nv">Это альтернативный текст.</span>][<span class="ss">myimage</span>] [<span class="nv">myimage</span>]: <span class="sx">relative/urls/cool/image.jpg</span> <span class="nn">"Если нужна подсказка, её можно добавить"</span></code></pre> ## Разное ### Автоссылки ```md Ссылка вида <http://testwebsite.com/> эквивалентна [http://testwebsite.com/](http://testwebsite.com/) ``` ### Автоссылки для адресов электронной почты ```md <foo@bar.com> ``` ### Экранирование символов ```md Я хочу напечатать *текст, заключённый в звёздочки*, но я не хочу, чтобы он был курсивным. Тогда я делаю так: \*Текст, заключённый в звёздочки\* ``` ### Клавиши на клавиатуре В Github Flavored Markdown для представления клавиш на клавиатуре вы можете использовать тег `<kbd>`. ```md Ваш компьютер завис? Попробуйте нажать <kbd>Ctrl</kbd>+<kbd>Alt</kbd>+<kbd>Del</kbd> ``` ### Таблицы Таблицы официально поддерживаются только в GitHub Flavored Markdown, да и синтаксис имеют не слишком удобный. Но если очень нужно, размечайте таблицы так: ```md | Столбец 1 | Столбец 2 | Столбец 3 | | :----------- | :----------: | -----------: | | Выравнивание | Выравнивание | Выравнивание | | влево | по центру | вправо | ``` Или более компактно ```md Столбец 1|Столбец 2|Столбец 3 :--|:-:|--: Выглядит|это|страшновато... ``` Ну вот и всё! За более подробной информацией обращайтесь к [статье](http://daringfireball.net/projects/markdown/syntax) Джона Грубера о синтаксисе Markdown. Также часто бывает полезной отличная ["шпаргалка"](https://github.com/adam-p/markdown-here/wiki/Markdown-Cheatsheet) по Markdown от Адама Притчарда.