Markdown parser, done right. 100% CommonMark support, extensions, syntax plugins & high speed
https://markdown-it.github.io/
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
1632 lines
265 KiB
1632 lines
265 KiB
8 months ago
|
<!DOCTYPE html><html><head><title>markdown-it 14.1.0 API documentation</title><meta charset="utf-8"><meta name="generator" content="ndoc"><style rel="stylesheet">article,
|
||
|
aside,
|
||
|
details,
|
||
|
figcaption,
|
||
|
figure,
|
||
|
footer,
|
||
|
header,
|
||
|
hgroup,
|
||
|
nav,
|
||
|
section {
|
||
|
display: block;
|
||
|
}
|
||
|
audio,
|
||
|
canvas,
|
||
|
video {
|
||
|
display: inline-block;
|
||
|
*display: inline;
|
||
|
*zoom: 1;
|
||
|
}
|
||
|
audio:not([controls]) {
|
||
|
display: none;
|
||
|
}
|
||
|
html {
|
||
|
font-size: 100%;
|
||
|
-webkit-text-size-adjust: 100%;
|
||
|
-ms-text-size-adjust: 100%;
|
||
|
}
|
||
|
a:hover,
|
||
|
a:active {
|
||
|
outline: 0;
|
||
|
}
|
||
|
sub,
|
||
|
sup {
|
||
|
position: relative;
|
||
|
font-size: 75%;
|
||
|
line-height: 0;
|
||
|
vertical-align: baseline;
|
||
|
}
|
||
|
sup {
|
||
|
top: -0.5em;
|
||
|
}
|
||
|
sub {
|
||
|
bottom: -0.25em;
|
||
|
}
|
||
|
img {
|
||
|
max-width: 100%;
|
||
|
height: auto;
|
||
|
border: 0;
|
||
|
-ms-interpolation-mode: bicubic;
|
||
|
}
|
||
|
button,
|
||
|
input,
|
||
|
select,
|
||
|
textarea {
|
||
|
margin: 0;
|
||
|
font-size: 100%;
|
||
|
vertical-align: middle;
|
||
|
}
|
||
|
button,
|
||
|
input {
|
||
|
*overflow: visible;
|
||
|
line-height: normal;
|
||
|
}
|
||
|
button::-moz-focus-inner,
|
||
|
input::-moz-focus-inner {
|
||
|
padding: 0;
|
||
|
border: 0;
|
||
|
}
|
||
|
button,
|
||
|
input[type="button"],
|
||
|
input[type="reset"],
|
||
|
input[type="submit"] {
|
||
|
cursor: pointer;
|
||
|
-webkit-appearance: button;
|
||
|
}
|
||
|
input[type="search"] {
|
||
|
-webkit-appearance: textfield;
|
||
|
box-sizing: content-box;
|
||
|
}
|
||
|
input[type="search"]::-webkit-search-decoration,
|
||
|
input[type="search"]::-webkit-search-cancel-button {
|
||
|
-webkit-appearance: none;
|
||
|
}
|
||
|
textarea {
|
||
|
overflow: auto;
|
||
|
vertical-align: top;
|
||
|
}
|
||
|
p {
|
||
|
margin: 0 0 11px;
|
||
|
font-family: Verdana, sans-serif;
|
||
|
font-size: 14px;
|
||
|
line-height: 22px;
|
||
|
}
|
||
|
p small {
|
||
|
font-size: 12px;
|
||
|
color: #999;
|
||
|
}
|
||
|
.lead {
|
||
|
margin-bottom: 22px;
|
||
|
font-size: 20px;
|
||
|
font-weight: 200;
|
||
|
line-height: 33px;
|
||
|
}
|
||
|
h1,
|
||
|
h2,
|
||
|
h3,
|
||
|
h4,
|
||
|
h5,
|
||
|
h6 {
|
||
|
margin: 0;
|
||
|
font-weight: normal;
|
||
|
color: #444;
|
||
|
text-rendering: optimizelegibility;
|
||
|
}
|
||
|
h1 small,
|
||
|
h2 small,
|
||
|
h3 small,
|
||
|
h4 small,
|
||
|
h5 small,
|
||
|
h6 small {
|
||
|
font-weight: normal;
|
||
|
color: #999;
|
||
|
}
|
||
|
h1 {
|
||
|
font-size: 36px;
|
||
|
line-height: 55px;
|
||
|
}
|
||
|
h1 small {
|
||
|
font-size: 18px;
|
||
|
}
|
||
|
h2 {
|
||
|
font-size: 30px;
|
||
|
line-height: 44px;
|
||
|
}
|
||
|
h2 small {
|
||
|
font-size: 18px;
|
||
|
}
|
||
|
h3 {
|
||
|
line-height: 44px;
|
||
|
font-size: 24px;
|
||
|
}
|
||
|
h3 small {
|
||
|
font-size: 18px;
|
||
|
}
|
||
|
h4,
|
||
|
h5,
|
||
|
h6 {
|
||
|
line-height: 22px;
|
||
|
}
|
||
|
h4 {
|
||
|
line-height: 33px;
|
||
|
font-size: 18px;
|
||
|
}
|
||
|
h4 small {
|
||
|
font-size: 14px;
|
||
|
}
|
||
|
h5 {
|
||
|
font-size: 14px;
|
||
|
}
|
||
|
h6 {
|
||
|
font-size: 12px;
|
||
|
color: #999;
|
||
|
text-transform: uppercase;
|
||
|
}
|
||
|
.page-header {
|
||
|
padding-bottom: 21px;
|
||
|
margin: 22px 0;
|
||
|
border-bottom: 1px solid #ccc;
|
||
|
}
|
||
|
.page-header h1 {
|
||
|
line-height: 1;
|
||
|
}
|
||
|
ul,
|
||
|
ol {
|
||
|
padding: 0;
|
||
|
margin: 0 0 11px 25px;
|
||
|
}
|
||
|
ul ul,
|
||
|
ul ol,
|
||
|
ol ol,
|
||
|
ol ul {
|
||
|
margin-bottom: 0;
|
||
|
}
|
||
|
ul {
|
||
|
list-style: disc;
|
||
|
}
|
||
|
ol {
|
||
|
list-style: decimal;
|
||
|
}
|
||
|
li {
|
||
|
line-height: 22px;
|
||
|
}
|
||
|
ul.unstyled,
|
||
|
ol.unstyled {
|
||
|
margin-left: 0;
|
||
|
list-style: none;
|
||
|
}
|
||
|
dl {
|
||
|
margin-bottom: 22px;
|
||
|
}
|
||
|
dt,
|
||
|
dd {
|
||
|
line-height: 22px;
|
||
|
}
|
||
|
dt {
|
||
|
font-weight: bold;
|
||
|
}
|
||
|
dd {
|
||
|
margin-left: 11px;
|
||
|
}
|
||
|
hr {
|
||
|
margin: 22px 0;
|
||
|
border: 0;
|
||
|
border-top: 1px solid hrBorder;
|
||
|
border-bottom: 1px solid #fff;
|
||
|
}
|
||
|
strong {
|
||
|
font-weight: bold;
|
||
|
}
|
||
|
em {
|
||
|
font-style: italic;
|
||
|
}
|
||
|
.muted {
|
||
|
color: #999;
|
||
|
}
|
||
|
abbr {
|
||
|
font-size: 90%;
|
||
|
text-transform: uppercase;
|
||
|
border-bottom: 1px dotted #ddd;
|
||
|
cursor: help;
|
||
|
}
|
||
|
blockquote {
|
||
|
padding: 0 0 0 15px;
|
||
|
margin: 0 0 22px;
|
||
|
border-left: 5px solid #ccc;
|
||
|
}
|
||
|
blockquote p {
|
||
|
margin-bottom: 0;
|
||
|
}
|
||
|
blockquote small {
|
||
|
display: block;
|
||
|
line-height: 22px;
|
||
|
color: #999;
|
||
|
}
|
||
|
blockquote small:before {
|
||
|
content: '\2014 \00A0';
|
||
|
}
|
||
|
blockquote.pull-right {
|
||
|
float: right;
|
||
|
padding-left: 0;
|
||
|
padding-right: 15px;
|
||
|
border-left: 0;
|
||
|
border-right: 5px solid #ccc;
|
||
|
}
|
||
|
blockquote.pull-right p,
|
||
|
blockquote.pull-right small {
|
||
|
text-align: right;
|
||
|
}
|
||
|
q:before,
|
||
|
q:after,
|
||
|
blockquote:before,
|
||
|
blockquote:after {
|
||
|
content: "";
|
||
|
}
|
||
|
address {
|
||
|
display: block;
|
||
|
margin-bottom: 22px;
|
||
|
line-height: 22px;
|
||
|
font-style: normal;
|
||
|
}
|
||
|
small {
|
||
|
font-size: 100%;
|
||
|
}
|
||
|
cite {
|
||
|
font-style: normal;
|
||
|
}
|
||
|
body {
|
||
|
margin: 0;
|
||
|
font-family: Verdana, sans-serif;
|
||
|
font-size: 14px;
|
||
|
line-height: 22px;
|
||
|
color: #444;
|
||
|
background-color: #fff;
|
||
|
overflow-x: hidden;
|
||
|
}
|
||
|
a {
|
||
|
color: #036;
|
||
|
text-decoration: none;
|
||
|
border-bottom: 1px solid #999;
|
||
|
}
|
||
|
a:hover {
|
||
|
color: #800;
|
||
|
border-color: #800;
|
||
|
}
|
||
|
.main {
|
||
|
padding-left: 390px;
|
||
|
width: 600px;
|
||
|
}
|
||
|
.sidebar {
|
||
|
background: #f8f8f8;
|
||
|
position: fixed;
|
||
|
top: 0;
|
||
|
bottom: 0;
|
||
|
left: 0;
|
||
|
width: 240px;
|
||
|
overflow: hidden;
|
||
|
}
|
||
|
#search {
|
||
|
background-color: #eee;
|
||
|
padding: 7px 0;
|
||
|
height: 30px;
|
||
|
box-shadow: 0 0 5px #aaa;
|
||
|
}
|
||
|
#search input {
|
||
|
width: 90%;
|
||
|
margin: auto;
|
||
|
margin-top: 3px;
|
||
|
padding: 4px;
|
||
|
display: block;
|
||
|
background-color: #f8f8f8;
|
||
|
border: 0px none;
|
||
|
border-radius: 3px;
|
||
|
box-shadow: 0 0 2px #666 inset;
|
||
|
}
|
||
|
#search-results {
|
||
|
z-index: 1000;
|
||
|
background-color: #f8fcf8;
|
||
|
display: none;
|
||
|
}
|
||
|
.footer {
|
||
|
border-top: 1px solid #eee;
|
||
|
font-size: 10px;
|
||
|
opacity: 0.5;
|
||
|
}
|
||
|
.gh-ribbon {
|
||
|
position: absolute;
|
||
|
right: -60px;
|
||
|
top: 44px;
|
||
|
z-index: 10000;
|
||
|
background-color: #686868;
|
||
|
padding: 1px 0;
|
||
|
transform: rotate(45deg);
|
||
|
width: 230px;
|
||
|
box-shadow: 0 0 2px rgba(102,102,102,0.4);
|
||
|
font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
|
||
|
}
|
||
|
.gh-ribbon a {
|
||
|
display: block;
|
||
|
color: #fff;
|
||
|
text-decoration: none;
|
||
|
border: 1px solid #ccc;
|
||
|
font-size: 13px;
|
||
|
font-weight: bold;
|
||
|
padding: 4px 50px 2px;
|
||
|
text-align: center;
|
||
|
outline: none;
|
||
|
}
|
||
|
.gh-ribbon a:hover {
|
||
|
text-decoration: none;
|
||
|
}
|
||
|
.csstransforms .gh-ribbon {
|
||
|
display: block;
|
||
|
}
|
||
|
.menu {
|
||
|
padding: 0;
|
||
|
margin: 0;
|
||
|
list-style: none;
|
||
|
top: 45px;
|
||
|
bottom: 0;
|
||
|
position: absolute;
|
||
|
overflow-x: hidden;
|
||
|
overflow-y: auto;
|
||
|
width: 240px;
|
||
|
}
|
||
|
.menu a {
|
||
|
border: 0;
|
||
|
padding: 3px 10px 3px 28px;
|
||
|
background-position: 6px 50%;
|
||
|
background-repeat: no-repeat;
|
||
|
display: block;
|
||
|
transition: all 0.3s ease;
|
||
|
color: #333;
|
||
|
display: block;
|
||
|
text-align: left;
|
||
|
text-decoration: none;
|
||
|
white-space: nowrap;
|
||
|
}
|
||
|
.menu a.deprecated {
|
||
|
opacity: 0.5;
|
||
|
}
|
||
|
.menu a.current {
|
||
|
background-color: #ddd;
|
||
|
}
|
||
|
.menu a.current-parent {
|
||
|
background-color: #eee;
|
||
|
}
|
||
|
.menu a:hover {
|
||
|
background-color: #ccc;
|
||
|
}
|
||
|
.menu a.section {
|
||
|
background-color: #000;
|
||
|
background: linear-gradient(#000 70%, #444) repeat scroll 0 0 transparent;
|
||
|
color: #ccc;
|
||
|
font-weight: bold;
|
||
|
padding: 6px 10px 6px 28px;
|
||
|
}
|
||
|
.menu a.class {
|
||
|
background-image: url("");
|
||
|
}
|
||
|
.menu a.class-method {
|
||
|
background-image: url("");
|
||
|
}
|
||
|
.menu a.class-property {
|
||
|
background-image: url("");
|
||
|
}
|
||
|
.menu a.constant {
|
||
|
background-image: url("");
|
||
|
}
|
||
|
.menu a.constructor {
|
||
|
background-image: url("");
|
||
|
}
|
||
|
.menu a.event {
|
||
|
background-image: url("");
|
||
|
}
|
||
|
.menu a.instance-method {
|
||
|
background-image: url("");
|
||
|
}
|
||
|
.menu a.instance-property {
|
||
|
background-image: url("");
|
||
|
}
|
||
|
.menu a.method {
|
||
|
background-image: url("");
|
||
|
}
|
||
|
.menu a.mixin {
|
||
|
background-image: url("");
|
||
|
}
|
||
|
.menu a.namespace {
|
||
|
background-image: url("");
|
||
|
}
|
||
|
.menu a.property {
|
||
|
background-image: url("");
|
||
|
}
|
||
|
.menu a.utility {
|
||
|
background-image: url("");
|
||
|
}
|
||
|
.menu ul {
|
||
|
padding: 0;
|
||
|
margin: 0;
|
||
|
list-style: none;
|
||
|
}
|
||
|
.menu ul a {
|
||
|
padding-left: 38px;
|
||
|
background-position: 16px 50%;
|
||
|
}
|
||
|
.menu ul ul a {
|
||
|
padding-left: 48px;
|
||
|
background-position: 26px 50%;
|
||
|
}
|
||
|
.menu ul ul ul a {
|
||
|
padding-left: 58px;
|
||
|
background-position: 36px 50%;
|
||
|
}
|
||
|
.menu ul ul ul ul a {
|
||
|
padding-left: 68px;
|
||
|
background-position: 46px 50%;
|
||
|
}
|
||
|
.docblock {
|
||
|
margin-bottom: 70px;
|
||
|
}
|
||
|
.docblock header {
|
||
|
margin-bottom: 22px;
|
||
|
}
|
||
|
.breadcrumbs {
|
||
|
font-size: 12px;
|
||
|
font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
|
||
|
white-space: nowrap;
|
||
|
margin-left: 0;
|
||
|
color: #ccc;
|
||
|
}
|
||
|
.breadcrumbs a {
|
||
|
color: #999;
|
||
|
border: 0;
|
||
|
}
|
||
|
.breadcrumbs a:hover {
|
||
|
text-decoration: underline;
|
||
|
}
|
||
|
.breadcrumbs li {
|
||
|
display: inline;
|
||
|
margin-right: 4px;
|
||
|
}
|
||
|
.breadcrumbs li + li:before {
|
||
|
content: "»";
|
||
|
margin-right: 4px;
|
||
|
}
|
||
|
header > .type {
|
||
|
color: #999;
|
||
|
text-transform: lowercase;
|
||
|
font-weight: bold;
|
||
|
font-style: italic;
|
||
|
font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
|
||
|
}
|
||
|
header .name_prefix {
|
||
|
opacity: 0.5;
|
||
|
}
|
||
|
header > .source {
|
||
|
line-height: 1em;
|
||
|
margin-bottom: 5.5px;
|
||
|
}
|
||
|
header > .source a {
|
||
|
font-size: 10px;
|
||
|
color: #ccc;
|
||
|
margin-left: 10px;
|
||
|
text-decoration: none;
|
||
|
border: 0;
|
||
|
}
|
||
|
header > .source a:hover {
|
||
|
text-decoration: underline;
|
||
|
}
|
||
|
.labels span {
|
||
|
border-radius: 3px 3px 3px 3px;
|
||
|
color: #fff;
|
||
|
font-size: 12px;
|
||
|
font-weight: bold;
|
||
|
padding: 2px 5px 3px;
|
||
|
text-transform: lower;
|
||
|
white-space: nowrap;
|
||
|
margin-right: 10px;
|
||
|
}
|
||
|
.labels span.read-only {
|
||
|
background-color: #999;
|
||
|
}
|
||
|
.labels span.internal {
|
||
|
background-color: #999;
|
||
|
}
|
||
|
.labels span.chainable {
|
||
|
background-color: #999;
|
||
|
}
|
||
|
.deprecated-note {
|
||
|
color: #f00;
|
||
|
}
|
||
|
.section {
|
||
|
position: relative;
|
||
|
}
|
||
|
.section h3 {
|
||
|
font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
|
||
|
background-position: right 3px;
|
||
|
background-repeat: no-repeat;
|
||
|
display: block;
|
||
|
position: absolute;
|
||
|
left: -145px;
|
||
|
top: 0;
|
||
|
width: 110px;
|
||
|
line-height: 14px;
|
||
|
padding-right: 20px;
|
||
|
padding-top: 4px;
|
||
|
padding-bottom: 4px;
|
||
|
margin: 0;
|
||
|
text-align: right;
|
||
|
font-weight: normal;
|
||
|
font-size: 14px;
|
||
|
color: #888;
|
||
|
}
|
||
|
.section.classes h3 {
|
||
|
background-image: url("");
|
||
|
line-height: 25px;
|
||
|
background-position: right 8px;
|
||
|
}
|
||
|
.section.class_methods h3 {
|
||
|
background-image: url("");
|
||
|
}
|
||
|
.section.class_properties h3 {
|
||
|
background-image: url("");
|
||
|
}
|
||
|
.section.constants h3 {
|
||
|
background-image: url("");
|
||
|
}
|
||
|
.section.constructor h3 {
|
||
|
background-image: url("");
|
||
|
}
|
||
|
.section.description h3 {
|
||
|
background-image: url("");
|
||
|
}
|
||
|
.section.events h3 {
|
||
|
background-image: url("");
|
||
|
}
|
||
|
.section.instance_methods h3 {
|
||
|
background-image: url("");
|
||
|
}
|
||
|
.section.instance_properties h3 {
|
||
|
background-image: url("");
|
||
|
}
|
||
|
.section.mixins h3 {
|
||
|
background-image: url("");
|
||
|
}
|
||
|
.section.namespaces h3 {
|
||
|
background-image: url("");
|
||
|
line-height: 25px;
|
||
|
background-position: right 8px;
|
||
|
}
|
||
|
.section.subclasses h3 {
|
||
|
background-image: url("");
|
||
|
}
|
||
|
.section.superclass h3 {
|
||
|
background-image: url("");
|
||
|
}
|
||
|
.section.utilities h3 {
|
||
|
background-image: url("");
|
||
|
}
|
||
|
.section.sections h3 {
|
||
|
background-image: url("");
|
||
|
line-height: 25px;
|
||
|
background-position: right 8px;
|
||
|
}
|
||
|
.method-list {
|
||
|
margin-left: 0;
|
||
|
list-style: none;
|
||
|
}
|
||
|
.method-list > li {
|
||
|
display: inline-block;
|
||
|
}
|
||
|
.method-list > li:after {
|
||
|
content: ",";
|
||
|
margin: 0 10px 0 2px;
|
||
|
}
|
||
|
.method-list > li:last-child:after {
|
||
|
content: '';
|
||
|
}
|
||
|
.method-list > li > a {
|
||
|
border-bottom: 1px solid #888;
|
||
|
text-decoration: none;
|
||
|
}
|
||
|
.method-details-list {
|
||
|
margin-left: 0;
|
||
|
list-style: none;
|
||
|
}
|
||
|
.method-description > h4 > a {
|
||
|
border-style: none none solid;
|
||
|
}
|
||
|
.section a,
|
||
|
.readme a {
|
||
|
border-style: none none dashed;
|
||
|
}
|
||
|
a.link-short,
|
||
|
.superclass a {
|
||
|
border-style: none none solid;
|
||
|
}
|
||
|
.note {
|
||
|
background-color: #eef;
|
||
|
border: 1px solid #69c;
|
||
|
}
|
||
|
.related-to {
|
||
|
background-color: #fff6de;
|
||
|
border: 1px solid #cc9;
|
||
|
}
|
||
|
.related-to > a {
|
||
|
margin-left: 25px;
|
||
|
}
|
||
|
.alias {
|
||
|
background-color: #fff6de;
|
||
|
border: 1px solid #cc9;
|
||
|
}
|
||
|
.alias > ul {
|
||
|
display: inline;
|
||
|
padding: 0;
|
||
|
}
|
||
|
.alias > ul > li {
|
||
|
display: inline;
|
||
|
}
|
||
|
.alias > ul > li:after {
|
||
|
content: ",";
|
||
|
margin: 0 5px 0 2px;
|
||
|
}
|
||
|
.alias > ul > li:last-child:after {
|
||
|
content: "";
|
||
|
margin: 0;
|
||
|
}
|
||
|
.note,
|
||
|
.related-to,
|
||
|
.alias {
|
||
|
border-radius: 3px;
|
||
|
font-size: 12px;
|
||
|
padding: 5px 30px;
|
||
|
margin-bottom: 11px;
|
||
|
}
|
||
|
.note a,
|
||
|
.related-to a,
|
||
|
.alias a {
|
||
|
border-style: none none solid;
|
||
|
}
|
||
|
.signatures {
|
||
|
background-color: #e0e8e0;
|
||
|
border: 1px solid #ccc;
|
||
|
border-radius: 3px;
|
||
|
padding: 5px 10px;
|
||
|
margin-left: 0;
|
||
|
list-style: none;
|
||
|
}
|
||
|
.signature {
|
||
|
list-style: none;
|
||
|
display: inline;
|
||
|
margin-left: 0;
|
||
|
}
|
||
|
.signature > li {
|
||
|
display: inline;
|
||
|
}
|
||
|
.signature-values {
|
||
|
list-style: none;
|
||
|
display: inline;
|
||
|
margin-left: 0;
|
||
|
}
|
||
|
.signature-values:before {
|
||
|
content: '→';
|
||
|
margin: 0 5px;
|
||
|
}
|
||
|
.signature-values > li {
|
||
|
display: inline;
|
||
|
}
|
||
|
.signature-values > li:after {
|
||
|
content: "|";
|
||
|
margin: 0 2px;
|
||
|
}
|
||
|
.signature-values > li:last-child:after {
|
||
|
content: "";
|
||
|
margin: 0;
|
||
|
}
|
||
|
.argument {
|
||
|
margin-left: 0;
|
||
|
display: inline;
|
||
|
}
|
||
|
.argument > li {
|
||
|
display: inline;
|
||
|
}
|
||
|
.argument-name {
|
||
|
color: #060;
|
||
|
font-weight: bold;
|
||
|
font-size: 13px;
|
||
|
}
|
||
|
.argument-types {
|
||
|
display: inline;
|
||
|
margin-left: 5px;
|
||
|
font-style: italic;
|
||
|
font-size: 11px;
|
||
|
}
|
||
|
.argument-types:before {
|
||
|
content: '(';
|
||
|
margin-right: 2px;
|
||
|
}
|
||
|
.argument-types:after {
|
||
|
content: ')';
|
||
|
margin-left: 2px;
|
||
|
}
|
||
|
.argument-types > li {
|
||
|
display: inline;
|
||
|
}
|
||
|
.argument-types > li:after {
|
||
|
content: "|";
|
||
|
margin: 0 2px;
|
||
|
}
|
||
|
.argument-types > li:last-child:after {
|
||
|
content: "";
|
||
|
margin: 0;
|
||
|
}
|
||
|
.argument-description p {
|
||
|
display: inline;
|
||
|
}
|
||
|
.argument-description:before {
|
||
|
content: '—';
|
||
|
margin-left: 5px;
|
||
|
margin-right: 5px;
|
||
|
}
|
||
|
code {
|
||
|
padding: 2px 4px;
|
||
|
font-size: 90%;
|
||
|
color: #c7254e;
|
||
|
background-color: #f9f2f4;
|
||
|
border-radius: 4px;
|
||
|
}
|
||
|
pre {
|
||
|
border: 1px solid #ccc;
|
||
|
border-radius: 4px;
|
||
|
}
|
||
|
pre code {
|
||
|
padding: 0;
|
||
|
font-size: inherit;
|
||
|
color: inherit;
|
||
|
background-color: transparent;
|
||
|
border-radius: 0;
|
||
|
}
|
||
|
.hljs {
|
||
|
display: block;
|
||
|
overflow-x: auto;
|
||
|
padding: 0.5em;
|
||
|
color: #333;
|
||
|
background: #f8f8f8;
|
||
|
}
|
||
|
.hljs-comment,
|
||
|
.hljs-quote {
|
||
|
color: #998;
|
||
|
font-style: italic;
|
||
|
}
|
||
|
.hljs-keyword,
|
||
|
.hljs-selector-tag,
|
||
|
.hljs-subst {
|
||
|
color: #333;
|
||
|
font-weight: bold;
|
||
|
}
|
||
|
.hljs-number,
|
||
|
.hljs-literal,
|
||
|
.hljs-variable,
|
||
|
.hljs-template-variable,
|
||
|
.hljs-tag .hljs-attr {
|
||
|
color: #008080;
|
||
|
}
|
||
|
.hljs-string,
|
||
|
.hljs-doctag {
|
||
|
color: #d14;
|
||
|
}
|
||
|
.hljs-title,
|
||
|
.hljs-section,
|
||
|
.hljs-selector-id {
|
||
|
color: #900;
|
||
|
font-weight: bold;
|
||
|
}
|
||
|
.hljs-subst {
|
||
|
font-weight: normal;
|
||
|
}
|
||
|
.hljs-type,
|
||
|
.hljs-class .hljs-title {
|
||
|
color: #458;
|
||
|
font-weight: bold;
|
||
|
}
|
||
|
.hljs-tag,
|
||
|
.hljs-name,
|
||
|
.hljs-attribute {
|
||
|
color: #000080;
|
||
|
font-weight: normal;
|
||
|
}
|
||
|
.hljs-regexp,
|
||
|
.hljs-link {
|
||
|
color: #009926;
|
||
|
}
|
||
|
.hljs-symbol,
|
||
|
.hljs-bullet {
|
||
|
color: #990073;
|
||
|
}
|
||
|
.hljs-built_in,
|
||
|
.hljs-builtin-name {
|
||
|
color: #0086b3;
|
||
|
}
|
||
|
.hljs-meta {
|
||
|
color: #999;
|
||
|
font-weight: bold;
|
||
|
}
|
||
|
.hljs-deletion {
|
||
|
background: #fdd;
|
||
|
}
|
||
|
.hljs-addition {
|
||
|
background: #dfd;
|
||
|
}
|
||
|
.hljs-emphasis {
|
||
|
font-style: italic;
|
||
|
}
|
||
|
.hljs-strong {
|
||
|
font-weight: bold;
|
||
|
}
|
||
|
.hljs {
|
||
|
padding: 9.5px;
|
||
|
}
|
||
|
|
||
|
</style><script type="text/javascript">/*! jQuery v3.7.1 | (c) OpenJS Foundation and other contributors | jquery.org/license */
|
||
|
!function(e,t){"use strict";"object"==typeof module&&"object"==typeof module.exports?module.exports=e.document?t(e,!0):function(e){if(!e.document)throw new Error("jQuery requires a window with a document");return t(e)}:t(e)}("undefined"!=typeof window?window:this,function(ie,e){"use strict";var oe=[],r=Object.getPrototypeOf,ae=oe.slice,g=oe.flat?function(e){return oe.flat.call(e)}:function(e){return oe.concat.apply([],e)},s=oe.push,se=oe.indexOf,n={},i=n.toString,ue=n.hasOwnProperty,o=ue.toString,a=o.call(Object),le={},v=function(e){return"function"==typeof e&&"number"!=typeof e.nodeType&&"function"!=typeof e.item},y=function(e){return null!=e&&e===e.window},C=ie.document,u={type:!0,src:!0,nonce:!0,noModule:!0};function m(e,t,n){var r,i,o=(n=n||C).createElement("script");if(o.text=e,t)for(r in u)(i=t[r]||t.getAttribute&&t.getAttribute(r))&&o.setAttribute(r,i);n.head.appendChild(o).parentNode.removeChild(o)}function x(e){return null==e?e+"":"object"==typeof e||"function"==typeof e?n[i.call(e)]||"object":typeof e}var t="3.7.1",l=/HTML$/i,ce=function(e,t){return new ce.fn.init(e,t)};function c(e){var t=!!e&&"length"in e&&e.length,n=x(e);return!v(e)&&!y(e)&&("array"===n||0===t||"number"==typeof t&&0<t&&t-1 in e)}function fe(e,t){return e.nodeName&&e.nodeName.toLowerCase()===t.toLowerCase()}ce.fn=ce.prototype={jquery:t,constructor:ce,length:0,toArray:function(){return ae.call(this)},get:function(e){return null==e?ae.call(this):e<0?this[e+this.length]:this[e]},pushStack:function(e){var t=ce.merge(this.constructor(),e);return t.prevObject=this,t},each:function(e){return ce.each(this,e)},map:function(n){return this.pushStack(ce.map(this,function(e,t){return n.call(e,t,e)}))},slice:function(){return this.pushStack(ae.apply(this,arguments))},first:function(){return this.eq(0)},last:function(){return this.eq(-1)},even:function(){return this.pushStack(ce.grep(this,function(e,t){return(t+1)%2}))},odd:function(){return this.pushStack(ce.grep(this,function(e,t){return t%2}))},eq:function(e){var t=this.length,n=+e+(e<0?t:0);return this.pushStack(0<=n&&n<t?[this[n]]:[])},end:function(){return this.prevObject||this.constructor()},push:s,sort:oe.sort,splice:oe.splice},ce.extend=ce.fn.extend=function(){var e,t,n,r,i,o,a=arguments[0]||{},s=1,u=arguments.length,l=!1;for("boolean"==typeof a&&(l=a,a=arguments[s]||{},s++),"object"==typeof a||v(a)||(a={}),s===u&&(a=this,s--);s<u;s++)if(null!=(e=arguments[s]))for(t in e)r=e[t],"__proto__"!==t&&a!==r&&(l&&r&&(ce.isPlainObject(r)||(i=Array.isArray(r)))?(n=a[t],o=i&&!Array.isArray(n)?[]:i||ce.isPlainObject(n)?n:{},i=!1,a[t]=ce.extend(l,o,r)):void 0!==r&&(a[t]=r));return a},ce.extend({expando:"jQuery"+(t+Math.random()).replace(/\D/g,""),isReady:!0,error:function(e){throw new Error(e)},noop:function(){},isPlainObject:function(e){var t,n;return!(!e||"[object Object]"!==i.call(e))&&(!(t=r(e))||"function"==typeof(n=ue.call(t,"constructor")&&t.constructor)&&o.call(n)===a)},isEmptyObject:function(e){var t;for(t in e)return!1;return!0},globalEval:function(e,t,n){m(e,{nonce:t&&t.nonce},n)},each:function(e,t){var n,r=0;if(c(e)){for(n=e.length;r<n;r++)if(!1===t.call(e[r],r,e[r]))break}else for(r in e)if(!1===t.call(e[r],r,e[r]))break;return e},text:function(e){var t,n="",r=0,i=e.nodeType;if(!i)while(t=e[r++])n+=ce.text(t);return 1===i||11===i?e.textContent:9===i?e.documentElement.textContent:3===i||4===i?e.nodeValue:n},makeArray:function(e,t){var n=t||[];return null!=e&&(c(Object(e))?ce.merge(n,"string"==typeof e?[e]:e):s.call(n,e)),n},inArray:function(e,t,n){return null==t?-1:se.call(t,e,n)},isXMLDoc:function(e){var t=e&&e.namespaceURI,n=e&&(e.ownerDocument||e).documentElement;return!l.test(t||n&&n.nodeName||"HTML")},merge:function(e,t){for(var n=+t.length,r=0,i=e.length;r<n;r++)e[i++]=t[r];return e.length=i,e},grep:function(e,t,n){for(var r=[],i=0,o=e.length,a=!n;i<o;i++)!t(e[i],i)!==a&&r.push(e[i]);return r},map:function(e,t,n){var r,i,o=0,a=[];if(c(e))for(r=e.length;o<r;o++)null!=(i=t(e[o],o,n))&&a.push(i);else for(o in e)null!=(i=t(e[o],o,n))&&a.push(i);return g(a)},guid:1,support:le}),"function"==typeof
|
||
|
$(function () {
|
||
|
'use strict';
|
||
|
|
||
|
var $empty = $(), // empty set used upon activtion
|
||
|
$window = $(window),
|
||
|
$items = $('.menu-item > a'),
|
||
|
$results = $('#search-results'), // search results
|
||
|
targets = [], // items and corresponding article offset
|
||
|
$active = null, // active article
|
||
|
baseTitle = document.title; // base (general) part of title
|
||
|
|
||
|
|
||
|
function throttle(func, ms) {
|
||
|
var isThrottled = false,
|
||
|
savedArgs,
|
||
|
savedThis;
|
||
|
|
||
|
function wrapper() {
|
||
|
if (isThrottled) { // (2)
|
||
|
savedArgs = arguments;
|
||
|
savedThis = this;
|
||
|
return;
|
||
|
}
|
||
|
|
||
|
func.apply(this, arguments); // (1)
|
||
|
isThrottled = true;
|
||
|
|
||
|
setTimeout(function() {
|
||
|
isThrottled = false; // (3)
|
||
|
if (savedArgs) {
|
||
|
wrapper.apply(savedThis, savedArgs);
|
||
|
savedArgs = savedThis = null;
|
||
|
}
|
||
|
}, ms);
|
||
|
}
|
||
|
|
||
|
return wrapper;
|
||
|
}
|
||
|
|
||
|
|
||
|
function getTitle($article) {
|
||
|
var title = [baseTitle];
|
||
|
|
||
|
if ($article.data('title')) {
|
||
|
title.push($article.data('title'));
|
||
|
}
|
||
|
|
||
|
return title.join(' | ');
|
||
|
}
|
||
|
|
||
|
function eachParent($item, callback) {
|
||
|
var $parent = $item.data('ndoc.parent');
|
||
|
if ($parent && $parent.length) {
|
||
|
eachParent($parent, callback);
|
||
|
callback($parent);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
// activates item (used upon scrolling)
|
||
|
function activate($article, expandParents) {
|
||
|
var $item;
|
||
|
|
||
|
if ($active) {
|
||
|
$item = $active.data('ndoc.item') || $empty;
|
||
|
$item.removeClass('current');
|
||
|
eachParent($item, function ($parent) {
|
||
|
$parent.removeClass('current-parent');
|
||
|
});
|
||
|
}
|
||
|
|
||
|
// set new active article
|
||
|
$active = $article;
|
||
|
|
||
|
// update title
|
||
|
document.title = getTitle($article);
|
||
|
|
||
|
$item = $active.data('ndoc.item') || $empty;
|
||
|
$item.addClass('current');
|
||
|
eachParent($item, function ($parent) {
|
||
|
$parent.addClass('current-parent');
|
||
|
if (expandParents) {
|
||
|
$parent.data('ndoc.childs')
|
||
|
.data('ndoc.collapsed', false)
|
||
|
.animate({
|
||
|
height: 'show',
|
||
|
opacity: 'show'
|
||
|
});
|
||
|
}
|
||
|
});
|
||
|
}
|
||
|
|
||
|
|
||
|
function processScroll(evt, expandParents) {
|
||
|
var scrollTop = $window.scrollTop() + 10, i = targets.length;
|
||
|
|
||
|
while (i--) {
|
||
|
if ($active !== targets[i].article && scrollTop >= targets[i].offset
|
||
|
&& (!targets[i + 1] || scrollTop <= targets[i + 1].offset)) {
|
||
|
activate(targets[i].article, expandParents);
|
||
|
return;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
// init articles
|
||
|
$('article.docblock').each(function () {
|
||
|
var $article = $(this);
|
||
|
|
||
|
targets.push({
|
||
|
article: $article,
|
||
|
offset: $article.offset().top
|
||
|
});
|
||
|
});
|
||
|
|
||
|
// init menu items
|
||
|
$items.each(function () {
|
||
|
var $item = $(this),
|
||
|
$childs = $item.next(),
|
||
|
$parent = $item.parents('ul').eq(0).prev().children(),
|
||
|
$article = $('[id="' + $item.attr('href').slice(1) + '"]');
|
||
|
|
||
|
// cross-refs
|
||
|
$item.data('ndoc.parent', $parent);
|
||
|
$item.data('ndoc.childs', $childs);
|
||
|
$article.data('ndoc.item', $item);
|
||
|
|
||
|
// bind activator
|
||
|
$item.on('click', function () {
|
||
|
if ($item.hasClass('current') && !$childs.data('ndoc.collapsed')) {
|
||
|
$childs.data('ndoc.collapsed', true).animate({
|
||
|
height: 'hide',
|
||
|
opacity: 'hide'
|
||
|
});
|
||
|
return false;
|
||
|
}
|
||
|
|
||
|
activate($article);
|
||
|
|
||
|
$childs.data('ndoc.collapsed', false).animate({
|
||
|
height: 'show',
|
||
|
opacity: 'show'
|
||
|
});
|
||
|
});
|
||
|
|
||
|
// collapse all 2nd levels
|
||
|
if (0 != $parent.length) {
|
||
|
$childs.data('ndoc.collapsed', true).hide();
|
||
|
}
|
||
|
});
|
||
|
|
||
|
function updateSearchResults() {
|
||
|
$results.empty();
|
||
|
|
||
|
if ('' == this.value) {
|
||
|
$results.hide();
|
||
|
return;
|
||
|
}
|
||
|
|
||
|
$results.show();
|
||
|
|
||
|
$items.filter('[data-id*="' + this.value.toLowerCase() + '"]').each(function () {
|
||
|
var $item = $(this);
|
||
|
$('<li class="menu-item">').append(
|
||
|
$item.clone(false)
|
||
|
.text($item.text())
|
||
|
.on('click', function () {
|
||
|
$item.trigger('click');
|
||
|
})
|
||
|
).appendTo($results);
|
||
|
});
|
||
|
}
|
||
|
|
||
|
// init search
|
||
|
$('#search')
|
||
|
// prevent from form submit
|
||
|
.on('submit', function () { return false; })
|
||
|
.find('input')
|
||
|
.on('keyup', throttle(updateSearchResults, 250))
|
||
|
// click - cuz i don't know what event fired on input clear in Chrome
|
||
|
.on('change click', updateSearchResults);
|
||
|
|
||
|
// init scrollspy
|
||
|
$window.on('scroll', throttle(processScroll, 250));
|
||
|
|
||
|
// initial jump (required for FF only - Chrome don't need it)
|
||
|
processScroll(null, true);
|
||
|
|
||
|
});
|
||
|
</script></head><body><div class="gh-ribbon"><a href="https://github.com/markdown-it/markdown-it">Fork me on GitHub</a></div><nav class="sidebar"><form id="search"><input type="search" size="20" title="Search" placeholder="Search"></form><ul class="menu" id="search-results"></ul><ul class="menu"><li class="menu-item"><a href="#Core" class="class internal" title="Core (class)" data-id="core">Core</a><ul><li class="menu-item"><a href="#Core.new" class="constructor" title="new Core (constructor)" data-id="new core">new</a></li><li class="menu-item"><a href="#Core.process" class="class-method" title="Core.process (class method)" data-id="core.process">process</a></li><li class="menu-item"><a href="#Core.prototype.ruler" class="instance-property" title="Core#ruler (instance property)" data-id="core#ruler">ruler</a></li></ul></li><li class="menu-item"><a href="#MarkdownIt" class="class" title="MarkdownIt (class)" data-id="markdownit">MarkdownIt</a><ul><li class="menu-item"><a href="#MarkdownIt.new" class="constructor" title="new MarkdownIt (constructor)" data-id="new markdownit">new</a></li><li class="menu-item"><a href="#MarkdownIt.configure" class="class-method chainable internal" title="MarkdownIt.configure (class method)" data-id="markdownit.configure">configure</a></li><li class="menu-item"><a href="#MarkdownIt.disable" class="class-method chainable" title="MarkdownIt.disable (class method)" data-id="markdownit.disable">disable</a></li><li class="menu-item"><a href="#MarkdownIt.enable" class="class-method chainable" title="MarkdownIt.enable (class method)" data-id="markdownit.enable">enable</a></li><li class="menu-item"><a href="#MarkdownIt.parse" class="class-method internal" title="MarkdownIt.parse (class method)" data-id="markdownit.parse">parse</a></li><li class="menu-item"><a href="#MarkdownIt.parseInline" class="class-method internal" title="MarkdownIt.parseInline (class method)" data-id="markdownit.parseinline">parseInline</a></li><li class="menu-item"><a href="#MarkdownIt.render" class="class-method" title="MarkdownIt.render (class method)" data-id="markdownit.render">render</a></li><li class="menu-item"><a href="#MarkdownIt.renderInline" class="class-method" title="MarkdownIt.renderInline (class method)" data-id="markdownit.renderinline">renderInline</a></li><li class="menu-item"><a href="#MarkdownIt.set" class="class-method chainable" title="MarkdownIt.set (class method)" data-id="markdownit.set">set</a></li><li class="menu-item"><a href="#MarkdownIt.use" class="class-method chainable" title="MarkdownIt.use (class method)" data-id="markdownit.use">use</a></li><li class="menu-item"><a href="#MarkdownIt.prototype.normalizeLink" class="instance-method" title="MarkdownIt#normalizeLink (instance method)" data-id="markdownit#normalizelink">normalizeLink</a></li><li class="menu-item"><a href="#MarkdownIt.prototype.normalizeLinkText" class="instance-method" title="MarkdownIt#normalizeLinkText (instance method)" data-id="markdownit#normalizelinktext">normalizeLinkText</a></li><li class="menu-item"><a href="#MarkdownIt.prototype.validateLink" class="instance-method" title="MarkdownIt#validateLink (instance method)" data-id="markdownit#validatelink">validateLink</a></li><li class="menu-item"><a href="#MarkdownIt.prototype.block" class="instance-property" title="MarkdownIt#block (instance property)" data-id="markdownit#block">block</a></li><li class="menu-item"><a href="#MarkdownIt.prototype.core" class="instance-property" title="MarkdownIt#core (instance property)" data-id="markdownit#core">core</a></li><li class="menu-item"><a href="#MarkdownIt.prototype.helpers" class="instance-property" title="MarkdownIt#helpers (instance property)" data-id="markdownit#helpers">helpers</a></li><li class="menu-item"><a href="#MarkdownIt.prototype.inline" class="instance-property" title="MarkdownIt#inline (instance property)" data-id="markdownit#inline">inline</a></li><li class="menu-item"><a href="#MarkdownIt.prototype.linkify" class="instance-property" title="MarkdownIt#linkify (instance property)" data-id="markdownit#linkify">linkify<
|
||
|
<h2>Install</h2>
|
||
|
<p><strong>node.js</strong>:</p>
|
||
|
<pre class="hljs language-bash"><code>npm install markdown-it
|
||
|
</code></pre>
|
||
|
<p><strong>browser (CDN):</strong></p>
|
||
|
<ul>
|
||
|
<li><a href="http://www.jsdelivr.com/#!markdown-it" title="jsDelivr CDN">jsDeliver CDN</a></li>
|
||
|
<li><a href="https://cdnjs.com/libraries/markdown-it" title="cdnjs.com">cdnjs.com CDN</a></li>
|
||
|
</ul>
|
||
|
<h2>Usage examples</h2>
|
||
|
<p>See also:</p>
|
||
|
<ul>
|
||
|
<li><a href="https://github.com/markdown-it/markdown-it/tree/master/docs">Development info</a> -
|
||
|
for plugins writers.</li>
|
||
|
</ul>
|
||
|
<h3>Simple</h3>
|
||
|
<pre class="hljs language-js"><code><span class="hljs-comment">// node.js</span>
|
||
|
<span class="hljs-comment">// can use `require('markdown-it')` for CJS</span>
|
||
|
<span class="hljs-keyword">import</span> markdownit <span class="hljs-keyword">from</span> <span class="hljs-string">'markdown-it'</span>
|
||
|
<span class="hljs-keyword">const</span> md = <span class="hljs-title function_">markdownit</span>()
|
||
|
<span class="hljs-keyword">const</span> result = md.<span class="hljs-title function_">render</span>(<span class="hljs-string">'# markdown-it rulezz!'</span>);
|
||
|
|
||
|
<span class="hljs-comment">// browser with UMD build, added to "window" on script load</span>
|
||
|
<span class="hljs-comment">// Note, there is no dash in "markdownit".</span>
|
||
|
<span class="hljs-keyword">const</span> md = <span class="hljs-variable language_">window</span>.<span class="hljs-title function_">markdownit</span>();
|
||
|
<span class="hljs-keyword">const</span> result = md.<span class="hljs-title function_">render</span>(<span class="hljs-string">'# markdown-it rulezz!'</span>);
|
||
|
</code></pre>
|
||
|
<p>Single line rendering, without paragraph wrap:</p>
|
||
|
<pre class="hljs language-js"><code><span class="hljs-keyword">import</span> markdownit <span class="hljs-keyword">from</span> <span class="hljs-string">'markdown-it'</span>
|
||
|
<span class="hljs-keyword">const</span> md = <span class="hljs-title function_">markdownit</span>()
|
||
|
<span class="hljs-keyword">const</span> result = md.<span class="hljs-title function_">renderInline</span>(<span class="hljs-string">'__markdown-it__ rulezz!'</span>);
|
||
|
</code></pre>
|
||
|
<h3>Init with presets and options</h3>
|
||
|
<p>(*) presets define combinations of active rules and options. Can be
|
||
|
<code>"commonmark"</code>, <code>"zero"</code> or <code>"default"</code> (if skipped). See
|
||
|
<a href="https://markdown-it.github.io/markdown-it/#MarkdownIt.new">API docs</a> for more details.</p>
|
||
|
<pre class="hljs language-js"><code><span class="hljs-keyword">import</span> markdownit <span class="hljs-keyword">from</span> <span class="hljs-string">'markdown-it'</span>
|
||
|
|
||
|
<span class="hljs-comment">// commonmark mode</span>
|
||
|
<span class="hljs-keyword">const</span> md = <span class="hljs-title function_">markdownit</span>(<span class="hljs-string">'commonmark'</span>)
|
||
|
|
||
|
<span class="hljs-comment">// default mode</span>
|
||
|
<span class="hljs-keyword">const</span> md = <span class="hljs-title function_">markdownit</span>()
|
||
|
|
||
|
<span class="hljs-comment">// enable everything</span>
|
||
|
<span class="hljs-keyword">const</span> md = <span class="hljs-title function_">markdownit</span>({
|
||
|
<span class="hljs-attr">html</span>: <span class="hljs-literal">true</span>,
|
||
|
<span class="hljs-attr">linkify</span>: <span class="hljs-literal">true</span>,
|
||
|
<span class="hljs-attr">typographer</span>: <span class="hljs-literal">true</span>
|
||
|
})
|
||
|
|
||
|
<span class="hljs-comment">// full options list (defaults)</span>
|
||
|
<span class="hljs-keyword">const</span> md = <span class="hljs-title function_">markdownit</span>({
|
||
|
<span class="hljs-comment">// Enable HTML tags in source</span>
|
||
|
<span class="hljs-attr">html</span>: <span class="hljs-literal">false</span>,
|
||
|
|
||
|
<span class="hljs-comment">// Use '/' to close single tags (<br />).</span>
|
||
|
<span class="hljs-comment">// This is only for full CommonMark compatibility.</span>
|
||
|
<span class="hljs-attr">xhtmlOut</span>: <span class="hljs-literal">false</span>,
|
||
|
|
||
|
<span class="hljs-comment">// Convert '\n' in paragraphs into <br></span>
|
||
|
<span class="hljs-attr">breaks</span>: <span class="hljs-literal">false</span>,
|
||
|
|
||
|
<span class="hljs-comment">// CSS language prefix for fenced blocks. Can be</span>
|
||
|
<span class="hljs-comment">// useful for external highlighters.</span>
|
||
|
<span class="hljs-attr">langPrefix</span>: <span class="hljs-string">'language-'</span>,
|
||
|
|
||
|
<span class="hljs-comment">// Autoconvert URL-like text to links</span>
|
||
|
<span class="hljs-attr">linkify</span>: <span class="hljs-literal">false</span>,
|
||
|
|
||
|
<span class="hljs-comment">// Enable some language-neutral replacement + quotes beautification</span>
|
||
|
<span class="hljs-comment">// For the full list of replacements, see https://github.com/markdown-it/markdown-it/blob/master/lib/rules_core/replacements.mjs</span>
|
||
|
<span class="hljs-attr">typographer</span>: <span class="hljs-literal">false</span>,
|
||
|
|
||
|
<span class="hljs-comment">// Double + single quotes replacement pairs, when typographer enabled,</span>
|
||
|
<span class="hljs-comment">// and smartquotes on. Could be either a String or an Array.</span>
|
||
|
<span class="hljs-comment">//</span>
|
||
|
<span class="hljs-comment">// For example, you can use '«»„“' for Russian, '„“‚‘' for German,</span>
|
||
|
<span class="hljs-comment">// and ['«\xA0', '\xA0»', '‹\xA0', '\xA0›'] for French (including nbsp).</span>
|
||
|
<span class="hljs-attr">quotes</span>: <span class="hljs-string">'“”‘’'</span>,
|
||
|
|
||
|
<span class="hljs-comment">// Highlighter function. Should return escaped HTML,</span>
|
||
|
<span class="hljs-comment">// or '' if the source string is not changed and should be escaped externally.</span>
|
||
|
<span class="hljs-comment">// If result starts with <pre... internal wrapper is skipped.</span>
|
||
|
<span class="hljs-attr">highlight</span>: <span class="hljs-keyword">function</span> (<span class="hljs-params"><span class="hljs-comment">/*str, lang*/</span></span>) { <span class="hljs-keyword">return</span> <span class="hljs-string">''</span>; }
|
||
|
});
|
||
|
</code></pre>
|
||
|
<h3>Plugins load</h3>
|
||
|
<pre class="hljs language-js"><code><span class="hljs-keyword">import</span> markdownit <span class="hljs-keyword">from</span> <span class="hljs-string">'markdown-it'</span>
|
||
|
|
||
|
<span class="hljs-keyword">const</span> md = markdownit
|
||
|
.<span class="hljs-title function_">use</span>(plugin1)
|
||
|
.<span class="hljs-title function_">use</span>(plugin2, opts, ...)
|
||
|
.<span class="hljs-title function_">use</span>(plugin3);
|
||
|
</code></pre>
|
||
|
<h3>Syntax highlighting</h3>
|
||
|
<p>Apply syntax highlighting to fenced code blocks with the <code>highlight</code> option:</p>
|
||
|
<pre class="hljs language-js"><code><span class="hljs-keyword">import</span> markdownit <span class="hljs-keyword">from</span> <span class="hljs-string">'markdown-it'</span>
|
||
|
<span class="hljs-keyword">import</span> hljs <span class="hljs-keyword">from</span> <span class="hljs-string">'highlight.js'</span> <span class="hljs-comment">// https://highlightjs.org</span>
|
||
|
|
||
|
<span class="hljs-comment">// Actual default values</span>
|
||
|
<span class="hljs-keyword">const</span> md = <span class="hljs-title function_">markdownit</span>({
|
||
|
<span class="hljs-attr">highlight</span>: <span class="hljs-keyword">function</span> (<span class="hljs-params">str, lang</span>) {
|
||
|
<span class="hljs-keyword">if</span> (lang && hljs.<span class="hljs-title function_">getLanguage</span>(lang)) {
|
||
|
<span class="hljs-keyword">try</span> {
|
||
|
<span class="hljs-keyword">return</span> hljs.<span class="hljs-title function_">highlight</span>(str, { <span class="hljs-attr">language</span>: lang }).<span class="hljs-property">value</span>;
|
||
|
} <span class="hljs-keyword">catch</span> (__) {}
|
||
|
}
|
||
|
|
||
|
<span class="hljs-keyword">return</span> <span class="hljs-string">''</span>; <span class="hljs-comment">// use external default escaping</span>
|
||
|
}
|
||
|
});
|
||
|
</code></pre>
|
||
|
<p>Or with full wrapper override (if you need assign class to <code><pre></code> or <code><code></code>):</p>
|
||
|
<pre class="hljs language-js"><code><span class="hljs-keyword">import</span> markdownit <span class="hljs-keyword">from</span> <span class="hljs-string">'markdown-it'</span>
|
||
|
<span class="hljs-keyword">import</span> hljs <span class="hljs-keyword">from</span> <span class="hljs-string">'highlight.js'</span> <span class="hljs-comment">// https://highlightjs.org</span>
|
||
|
|
||
|
<span class="hljs-comment">// Actual default values</span>
|
||
|
<span class="hljs-keyword">const</span> md = <span class="hljs-title function_">markdownit</span>({
|
||
|
<span class="hljs-attr">highlight</span>: <span class="hljs-keyword">function</span> (<span class="hljs-params">str, lang</span>) {
|
||
|
<span class="hljs-keyword">if</span> (lang && hljs.<span class="hljs-title function_">getLanguage</span>(lang)) {
|
||
|
<span class="hljs-keyword">try</span> {
|
||
|
<span class="hljs-keyword">return</span> <span class="hljs-string">'<pre><code class="hljs">'</span> +
|
||
|
hljs.<span class="hljs-title function_">highlight</span>(str, { <span class="hljs-attr">language</span>: lang, <span class="hljs-attr">ignoreIllegals</span>: <span class="hljs-literal">true</span> }).<span class="hljs-property">value</span> +
|
||
|
<span class="hljs-string">'</code></pre>'</span>;
|
||
|
} <span class="hljs-keyword">catch</span> (__) {}
|
||
|
}
|
||
|
|
||
|
<span class="hljs-keyword">return</span> <span class="hljs-string">'<pre><code class="hljs">'</span> + md.<span class="hljs-property">utils</span>.escapeHtml(str) + <span class="hljs-string">'</code></pre>'</span>;
|
||
|
}
|
||
|
});
|
||
|
</code></pre>
|
||
|
<h3>Linkify</h3>
|
||
|
<p><code>linkify: true</code> uses <a href="https://github.com/markdown-it/linkify-it">linkify-it</a>. To
|
||
|
configure linkify-it, access the linkify instance through <code>md.linkify</code>:</p>
|
||
|
<pre class="hljs language-js"><code>md.<span class="hljs-property">linkify</span>.<span class="hljs-title function_">set</span>({ <span class="hljs-attr">fuzzyEmail</span>: <span class="hljs-literal">false</span> }); <span class="hljs-comment">// disables converting email to link</span>
|
||
|
</code></pre>
|
||
|
<h2>Syntax extensions</h2>
|
||
|
<p>Embedded (enabled by default):</p>
|
||
|
<ul>
|
||
|
<li><a href="https://help.github.com/articles/organizing-information-with-tables/">Tables</a> (GFM)</li>
|
||
|
<li><a href="https://help.github.com/articles/basic-writing-and-formatting-syntax/#styling-text">Strikethrough</a> (GFM)</li>
|
||
|
</ul>
|
||
|
<p>Via plugins:</p>
|
||
|
<ul>
|
||
|
<li><a href="https://github.com/markdown-it/markdown-it-sub">subscript</a></li>
|
||
|
<li><a href="https://github.com/markdown-it/markdown-it-sup">superscript</a></li>
|
||
|
<li><a href="https://github.com/markdown-it/markdown-it-footnote">footnote</a></li>
|
||
|
<li><a href="https://github.com/markdown-it/markdown-it-deflist">definition list</a></li>
|
||
|
<li><a href="https://github.com/markdown-it/markdown-it-abbr">abbreviation</a></li>
|
||
|
<li><a href="https://github.com/markdown-it/markdown-it-emoji">emoji</a></li>
|
||
|
<li><a href="https://github.com/markdown-it/markdown-it-container">custom container</a></li>
|
||
|
<li><a href="https://github.com/markdown-it/markdown-it-ins">insert</a></li>
|
||
|
<li><a href="https://github.com/markdown-it/markdown-it-mark">mark</a></li>
|
||
|
<li>... and <a href="https://www.npmjs.org/browse/keyword/markdown-it-plugin">others</a></li>
|
||
|
</ul>
|
||
|
<h3>Manage rules</h3>
|
||
|
<p>By default all rules are enabled, but can be restricted by options. On plugin
|
||
|
load all its rules are enabled automatically.</p>
|
||
|
<pre class="hljs language-js"><code><span class="hljs-keyword">import</span> markdownit <span class="hljs-keyword">from</span> <span class="hljs-string">'markdown-it'</span>
|
||
|
|
||
|
<span class="hljs-comment">// Activate/deactivate rules, with currying</span>
|
||
|
<span class="hljs-keyword">const</span> md = <span class="hljs-title function_">markdownit</span>()
|
||
|
.<span class="hljs-title function_">disable</span>([<span class="hljs-string">'link'</span>, <span class="hljs-string">'image'</span>])
|
||
|
.<span class="hljs-title function_">enable</span>([<span class="hljs-string">'link'</span>])
|
||
|
.<span class="hljs-title function_">enable</span>(<span class="hljs-string">'image'</span>);
|
||
|
|
||
|
<span class="hljs-comment">// Enable everything</span>
|
||
|
<span class="hljs-keyword">const</span> md = <span class="hljs-title function_">markdownit</span>({
|
||
|
<span class="hljs-attr">html</span>: <span class="hljs-literal">true</span>,
|
||
|
<span class="hljs-attr">linkify</span>: <span class="hljs-literal">true</span>,
|
||
|
<span class="hljs-attr">typographer</span>: <span class="hljs-literal">true</span>,
|
||
|
});
|
||
|
</code></pre>
|
||
|
</div></article><article class="docblock" id="Core" data-title="Core (class)"><header><ul class="breadcrumbs"><li><a href="#home">Home</a></li><li><a href="#Core" class="" title="Core (class)" data-id="core">Core</a></li></ul><h2 title="class">Core</h2><div class="source"><a href="https://github.com/markdown-it/markdown-it/blob/0fe7cc/lib/parser_core.mjs#L7">View source</a></div><div class="labels"><span class="internal">internal</span></div></header><div class="section description"><h3>Description</h3><div class="content"><p>Top-level rules executor. Glues block/inline parsers and does intermediate
|
||
|
transformations.</p>
|
||
|
</div></div><div class="section constructor"><h3>Constructor</h3><div class="content"></div><ul class="method-list"><li><a href="#Core.new" class="" title="new Core (constructor)" data-id="new core">new Core</a></li></ul></div><div class="section class_methods"><h3>Class methods</h3><div class="content"><ul class="method-list"><li><a href="#Core.process" class="" title="Core.process (class method)" data-id="core.process">process</a></li></ul></div></div><div class="section instance_properties"><h3>Instance properties</h3><div class="content"><ul class="method-list"><li><a href="#Core.prototype.ruler" class="" title="Core#ruler (instance property)" data-id="core#ruler">ruler</a></li></ul></div></div></article><article class="docblock" id="Core.new" data-title="new Core (constructor)"><header><ul class="breadcrumbs"><li><a href="#home">Home</a></li><li><a href="#Core" class="" title="Core (class)" data-id="core">Core</a></li><li><a href="#Core.new" class="" title="new Core (constructor)" data-id="new core">new</a></li></ul><h2 title="constructor"><span class="name_prefix">Core.</span>new</h2><div class="source"><a href="https://github.com/markdown-it/markdown-it/blob/0fe7cc/lib/parser_core.mjs#L34">View source</a></div></header><div class="section method"><div class="content"><ul class="signatures"><li><ul class="signature"><li class="signature-call">new Core()</li></ul></li></ul></div></div></article><article class="docblock" id="Core.process" data-title="Core.process (class method)"><header><ul class="breadcrumbs"><li><a href="#home">Home</a></li><li><a href="#Core" class="" title="Core (class)" data-id="core">Core</a></li><li><a href="#Core.process" class="" title="Core.process (class method)" data-id="core.process">process</a></li></ul><h2 title="class method"><span class="name_prefix">Core.</span>process</h2><div class="source"><a href="https://github.com/markdown-it/markdown-it/blob/0fe7cc/lib/parser_core.mjs#L52">View source</a></div></header><div class="section method"><div class="content"><ul class="signatures"><li><ul class="signature"><li class="signature-call">Core.process(state)</li></ul></li></ul><p>Executes core chain rules.</p>
|
||
|
</div></div></article><article class="docblock" id="Core.prototype.ruler" data-title="Core#ruler (instance property)"><header><ul class="breadcrumbs"><li><a href="#home">Home</a></li><li><a href="#Core" class="" title="Core (class)" data-id="core">Core</a></li><li><a href="#Core.prototype.ruler" class="" title="Core#ruler (instance property)" data-id="core#ruler">ruler</a></li></ul><h2 title="instance property"><span class="name_prefix">Core#</span>ruler</h2><div class="source"><a href="https://github.com/markdown-it/markdown-it/blob/0fe7cc/lib/parser_core.mjs#L40">View source</a></div></header><div class="section method"><div class="content"><ul class="signatures"><li><ul class="signature"><li class="signature-call">Core#ruler</li><li><ul class="signature-values"><li><a href="#Ruler" class="link-short" title="Ruler (class)" data-id="ruler">Ruler</a></li></ul></li></ul></li></ul><p><a href="#Ruler" class="link-short" title="Ruler (class)" data-id="ruler">Ruler</a> instance. Keep configuration of core rules.</p>
|
||
|
</div></div></article><article class="docblock" id="MarkdownIt" data-title="MarkdownIt (class)"><header><ul class="breadcrumbs"><li><a href="#home">Home</a></li><li><a href="#MarkdownIt" class="" title="MarkdownIt (class)" data-id="markdownit">MarkdownIt</a></li></ul><h2 title="class">MarkdownIt</h2><div class="source"><a href="https://github.com/markdown-it/markdown-it/blob/0fe7cc/lib/index.mjs#L114">View source</a></div></header><div class="section description"><h3>Description</h3><div class="content"><p>Main parser/renderer class.</p>
|
||
|
<h5>Usage</h5>
|
||
|
<pre class="hljs language-javascript"><code><span class="hljs-comment">// node.js, "classic" way:</span>
|
||
|
<span class="hljs-keyword">var</span> <span class="hljs-title class_">MarkdownIt</span> = <span class="hljs-built_in">require</span>(<span class="hljs-string">'markdown-it'</span>),
|
||
|
md = <span class="hljs-keyword">new</span> <span class="hljs-title class_">MarkdownIt</span>();
|
||
|
<span class="hljs-keyword">var</span> result = md.<span class="hljs-title function_">render</span>(<span class="hljs-string">'# markdown-it rulezz!'</span>);
|
||
|
|
||
|
<span class="hljs-comment">// node.js, the same, but with sugar:</span>
|
||
|
<span class="hljs-keyword">var</span> md = <span class="hljs-built_in">require</span>(<span class="hljs-string">'markdown-it'</span>)();
|
||
|
<span class="hljs-keyword">var</span> result = md.<span class="hljs-title function_">render</span>(<span class="hljs-string">'# markdown-it rulezz!'</span>);
|
||
|
|
||
|
<span class="hljs-comment">// browser without AMD, added to "window" on script load</span>
|
||
|
<span class="hljs-comment">// Note, there are no dash.</span>
|
||
|
<span class="hljs-keyword">var</span> md = <span class="hljs-variable language_">window</span>.<span class="hljs-title function_">markdownit</span>();
|
||
|
<span class="hljs-keyword">var</span> result = md.<span class="hljs-title function_">render</span>(<span class="hljs-string">'# markdown-it rulezz!'</span>);
|
||
|
</code></pre>
|
||
|
<p>Single line rendering, without paragraph wrap:</p>
|
||
|
<pre class="hljs language-javascript"><code><span class="hljs-keyword">var</span> md = <span class="hljs-built_in">require</span>(<span class="hljs-string">'markdown-it'</span>)();
|
||
|
<span class="hljs-keyword">var</span> result = md.<span class="hljs-title function_">renderInline</span>(<span class="hljs-string">'__markdown-it__ rulezz!'</span>);
|
||
|
</code></pre>
|
||
|
</div></div><div class="section constructor"><h3>Constructor</h3><div class="content"></div><ul class="method-list"><li><a href="#MarkdownIt.new" class="" title="new MarkdownIt (constructor)" data-id="new markdownit">new MarkdownIt</a></li></ul></div><div class="section class_methods"><h3>Class methods</h3><div class="content"><ul class="method-list"><li><a href="#MarkdownIt.configure" class="" title="MarkdownIt.configure (class method)" data-id="markdownit.configure">configure</a></li><li><a href="#MarkdownIt.disable" class="" title="MarkdownIt.disable (class method)" data-id="markdownit.disable">disable</a></li><li><a href="#MarkdownIt.enable" class="" title="MarkdownIt.enable (class method)" data-id="markdownit.enable">enable</a></li><li><a href="#MarkdownIt.parse" class="" title="MarkdownIt.parse (class method)" data-id="markdownit.parse">parse</a></li><li><a href="#MarkdownIt.parseInline" class="" title="MarkdownIt.parseInline (class method)" data-id="markdownit.parseinline">parseInline</a></li><li><a href="#MarkdownIt.render" class="" title="MarkdownIt.render (class method)" data-id="markdownit.render">render</a></li><li><a href="#MarkdownIt.renderInline" class="" title="MarkdownIt.renderInline (class method)" data-id="markdownit.renderinline">renderInline</a></li><li><a href="#MarkdownIt.set" class="" title="MarkdownIt.set (class method)" data-id="markdownit.set">set</a></li><li><a href="#MarkdownIt.use" class="" title="MarkdownIt.use (class method)" data-id="markdownit.use">use</a></li></ul></div></div><div class="section instance_methods"><h3>Instance methods</h3><div class="content"><ul class="method-list"><li><a href="#MarkdownIt.prototype.normalizeLink" class="" title="MarkdownIt#normalizeLink (instance method)" data-id="markdownit#normalizelink">normalizeLink</a></li><li><a href="#MarkdownIt.prototype.normalizeLinkText" class="" title="MarkdownIt#normalizeLinkText (instance method)" data-id="markdownit#normalizelinktext">normalizeLinkText</a></li><li><a href="#MarkdownIt.prototype.validateLink" class="" title="MarkdownIt#validateLink (instance method)" data-id="markdownit#validatelink">validateLink</a></li></ul></div></div><div class="section instance_properties"><h3>Instance properties</h3><div class="content"><ul class="method-list"><li><a href="#MarkdownIt.prototype.block" class="" title="MarkdownIt#block (instance property)" data-id="markdownit#block">block</a></li><li><a href="#MarkdownIt.prototype.core" class="" title="MarkdownIt#core (instance property)" data-id="markdownit#core">core</a></li><li><a href="#MarkdownIt.prototype.helpers" class="" title="MarkdownIt#helpers (instance property)" data-id="markdownit#helpers">helpers</a></li><li><a href="#MarkdownIt.prototype.inline" class="" title="MarkdownIt#inline (instance property)" data-id="markdownit#inline">inline</a></li><li><a href="#MarkdownIt.prototype.linkify" class="" title="MarkdownIt#linkify (instance property)" data-id="markdownit#linkify">linkify</a></li><li><a href="#MarkdownIt.prototype.renderer" class="" title="MarkdownIt#renderer (instance property)" data-id="markdownit#renderer">renderer</a></li><li><a href="#MarkdownIt.prototype.utils" class="" title="MarkdownIt#utils (instance property)" data-id="markdownit#utils">utils</a></li></ul></div></div></article><article class="docblock" id="MarkdownIt.new" data-title="new MarkdownIt (constructor)"><header><ul class="breadcrumbs"><li><a href="#home">Home</a></li><li><a href="#MarkdownIt" class="" title="MarkdownIt (class)" data-id="markdownit">MarkdownIt</a></li><li><a href="#MarkdownIt.new" class="" title="new MarkdownIt (constructor)" data-id="new markdownit">new</a></li></ul><h2 title="constructor"><span class="name_prefix">MarkdownIt.</span>new</h2><div class="source"><a href="https://github.com/markdown-it/markdown-it/blob/0fe7cc/lib/index.mjs#L217">View source</a></div></header><div class="section method"><div class="content"><ul class="signatures"><li><ul class="signature"><li class="signature-call">new MarkdownIt([presetName][, options])</li></ul></li></ul><ul class="arguments"><li>
|
||
|
</li></ul></li><li><ul class="argument"><li class="argument-name">options</li><li><ul class="argument-types"><li class="argument-type">Object</li></ul></li></ul></li></ul><p>Creates parser instanse with given config. Can be called without <code>new</code>.</p>
|
||
|
<h5>presetName</h5>
|
||
|
<p>MarkdownIt provides named presets as a convenience to quickly
|
||
|
enable/disable active syntax rules and options for common use cases.</p>
|
||
|
<ul>
|
||
|
<li><a href="https://github.com/markdown-it/markdown-it/blob/master/lib/presets/commonmark.mjs">"commonmark"</a> -
|
||
|
configures parser to strict <a href="http://commonmark.org/">CommonMark</a> mode.</li>
|
||
|
<li><a href="https://github.com/markdown-it/markdown-it/blob/master/lib/presets/default.mjs">default</a> -
|
||
|
similar to GFM, used when no preset name given. Enables all available rules,
|
||
|
but still without html, typographer & autolinker.</li>
|
||
|
<li><a href="https://github.com/markdown-it/markdown-it/blob/master/lib/presets/zero.mjs">"zero"</a> -
|
||
|
all rules disabled. Useful to quickly setup your config via <code>.enable()</code>.
|
||
|
For example, when you need only <code>bold</code> and <code>italic</code> markup and nothing else.</li>
|
||
|
</ul>
|
||
|
<h5>options:</h5>
|
||
|
<ul>
|
||
|
<li><strong>html</strong> - <code>false</code>. Set <code>true</code> to enable HTML tags in source. Be careful!
|
||
|
That's not safe! You may need external sanitizer to protect output from XSS.
|
||
|
It's better to extend features via plugins, instead of enabling HTML.</li>
|
||
|
<li><strong>xhtmlOut</strong> - <code>false</code>. Set <code>true</code> to add '/' when closing single tags
|
||
|
(<code><br /></code>). This is needed only for full CommonMark compatibility. In real
|
||
|
world you will need HTML output.</li>
|
||
|
<li><strong>breaks</strong> - <code>false</code>. Set <code>true</code> to convert <code>\n</code> in paragraphs into <code><br></code>.</li>
|
||
|
<li><strong>langPrefix</strong> - <code>language-</code>. CSS language class prefix for fenced blocks.
|
||
|
Can be useful for external highlighters.</li>
|
||
|
<li><strong>linkify</strong> - <code>false</code>. Set <code>true</code> to autoconvert URL-like text to links.</li>
|
||
|
<li><strong>typographer</strong> - <code>false</code>. Set <code>true</code> to enable <a href="https://github.com/markdown-it/markdown-it/blob/master/lib/rules_core/replacements.mjs">some language-neutral
|
||
|
replacement</a> +
|
||
|
quotes beautification (smartquotes).</li>
|
||
|
<li><strong>quotes</strong> - <code>“”‘’</code>, String or Array. Double + single quotes replacement
|
||
|
pairs, when typographer enabled and smartquotes on. For example, you can
|
||
|
use <code>'«»„“'</code> for Russian, <code>'„“‚‘'</code> for German, and
|
||
|
<code>['«\xA0', '\xA0»', '‹\xA0', '\xA0›']</code> for French (including nbsp).</li>
|
||
|
<li><strong>highlight</strong> - <code>null</code>. Highlighter function for fenced code blocks.
|
||
|
Highlighter <code>function (str, lang)</code> should return escaped HTML. It can also
|
||
|
return empty string if the source was not changed and should be escaped
|
||
|
externaly. If result starts with <pre... internal wrapper is skipped.</li>
|
||
|
</ul>
|
||
|
<h5>Example</h5>
|
||
|
<pre class="hljs language-javascript"><code><span class="hljs-comment">// commonmark mode</span>
|
||
|
<span class="hljs-keyword">var</span> md = <span class="hljs-built_in">require</span>(<span class="hljs-string">'markdown-it'</span>)(<span class="hljs-string">'commonmark'</span>);
|
||
|
|
||
|
<span class="hljs-comment">// default mode</span>
|
||
|
<span class="hljs-keyword">var</span> md = <span class="hljs-built_in">require</span>(<span class="hljs-string">'markdown-it'</span>)();
|
||
|
|
||
|
<span class="hljs-comment">// enable everything</span>
|
||
|
<span class="hljs-keyword">var</span> md = <span class="hljs-built_in">require</span>(<span class="hljs-string">'markdown-it'</span>)({
|
||
|
<span class="hljs-attr">html</span>: <span class="hljs-literal">true</span>,
|
||
|
<span class="hljs-attr">linkify</span>: <span class="hljs-literal">true</span>,
|
||
|
<span class="hljs-attr">typographer</span>: <span class="hljs-literal">true</span>
|
||
|
});
|
||
|
</code></pre>
|
||
|
<h5>Syntax highlighting</h5>
|
||
|
<pre class="hljs language-js"><code><span class="hljs-keyword">var</span> hljs = <span class="hljs-built_in">require</span>(<span class="hljs-string">'highlight.js'</span>) <span class="hljs-comment">// https://highlightjs.org/</span>
|
||
|
|
||
|
<span class="hljs-keyword">var</span> md = <span class="hljs-built_in">require</span>(<span class="hljs-string">'markdown-it'</span>)({
|
||
|
<span class="hljs-attr">highlight</span>: <span class="hljs-keyword">function</span> (<span class="hljs-params">str, lang</span>) {
|
||
|
<span class="hljs-keyword">if</span> (lang && hljs.<span class="hljs-title function_">getLanguage</span>(lang)) {
|
||
|
<span class="hljs-keyword">try</span> {
|
||
|
<span class="hljs-keyword">return</span> hljs.<span class="hljs-title function_">highlight</span>(str, { <span class="hljs-attr">language</span>: lang, <span class="hljs-attr">ignoreIllegals</span>: <span class="hljs-literal">true</span> }).<span class="hljs-property">value</span>;
|
||
|
} <span class="hljs-keyword">catch</span> (__) {}
|
||
|
}
|
||
|
|
||
|
<span class="hljs-keyword">return</span> <span class="hljs-string">''</span>; <span class="hljs-comment">// use external default escaping</span>
|
||
|
}
|
||
|
});
|
||
|
</code></pre>
|
||
|
<p>Or with full wrapper override (if you need assign class to <code><pre></code> or <code><code></code>):</p>
|
||
|
<pre class="hljs language-javascript"><code><span class="hljs-keyword">var</span> hljs = <span class="hljs-built_in">require</span>(<span class="hljs-string">'highlight.js'</span>) <span class="hljs-comment">// https://highlightjs.org/</span>
|
||
|
|
||
|
<span class="hljs-comment">// Actual default values</span>
|
||
|
<span class="hljs-keyword">var</span> md = <span class="hljs-built_in">require</span>(<span class="hljs-string">'markdown-it'</span>)({
|
||
|
<span class="hljs-attr">highlight</span>: <span class="hljs-keyword">function</span> (<span class="hljs-params">str, lang</span>) {
|
||
|
<span class="hljs-keyword">if</span> (lang && hljs.<span class="hljs-title function_">getLanguage</span>(lang)) {
|
||
|
<span class="hljs-keyword">try</span> {
|
||
|
<span class="hljs-keyword">return</span> <span class="hljs-string">'<pre><code class="hljs">'</span> +
|
||
|
hljs.<span class="hljs-title function_">highlight</span>(str, { <span class="hljs-attr">language</span>: lang, <span class="hljs-attr">ignoreIllegals</span>: <span class="hljs-literal">true</span> }).<span class="hljs-property">value</span> +
|
||
|
<span class="hljs-string">'</code></pre>'</span>;
|
||
|
} <span class="hljs-keyword">catch</span> (__) {}
|
||
|
}
|
||
|
|
||
|
<span class="hljs-keyword">return</span> <span class="hljs-string">'<pre><code class="hljs">'</span> + md.<span class="hljs-property">utils</span>.escapeHtml(str) + <span class="hljs-string">'</code></pre>'</span>;
|
||
|
}
|
||
|
});
|
||
|
</code></pre>
|
||
|
</div></div></article><article class="docblock" id="MarkdownIt.configure" data-title="MarkdownIt.configure (class method)"><header><ul class="breadcrumbs"><li><a href="#home">Home</a></li><li><a href="#MarkdownIt" class="" title="MarkdownIt (class)" data-id="markdownit">MarkdownIt</a></li><li><a href="#MarkdownIt.configure" class="" title="MarkdownIt.configure (class method)" data-id="markdownit.configure">configure</a></li></ul><h2 title="class method"><span class="name_prefix">MarkdownIt.</span>configure</h2><div class="source"><a href="https://github.com/markdown-it/markdown-it/blob/0fe7cc/lib/index.mjs#L378">View source</a></div><div class="labels"><span class="chainable">chainable</span><span class="internal">internal</span></div></header><div class="section method"><div class="content"><ul class="signatures"><li><ul class="signature"><li class="signature-call">MarkdownIt.configure(presets)</li></ul></li></ul><p>Batch load of all options and compenent settings. This is internal method,
|
||
|
and you probably will not need it. But if you will - see available presets
|
||
|
and data structure <a href="https://github.com/markdown-it/markdown-it/tree/master/lib/presets">here</a></p>
|
||
|
<p>We strongly recommend to use presets instead of direct config loads. That
|
||
|
will give better compatibility with next versions.</p>
|
||
|
</div></div></article><article class="docblock" id="MarkdownIt.disable" data-title="MarkdownIt.disable (class method)"><header><ul class="breadcrumbs"><li><a href="#home">Home</a></li><li><a href="#MarkdownIt" class="" title="MarkdownIt (class)" data-id="markdownit">MarkdownIt</a></li><li><a href="#MarkdownIt.disable" class="" title="MarkdownIt.disable (class method)" data-id="markdownit.disable">disable</a></li></ul><h2 title="class method"><span class="name_prefix">MarkdownIt.</span>disable</h2><div class="source"><a href="https://github.com/markdown-it/markdown-it/blob/0fe7cc/lib/index.mjs#L448">View source</a></div><div class="labels"><span class="chainable">chainable</span></div></header><div class="section method"><div class="content"><ul class="signatures"><li><ul class="signature"><li class="signature-call">MarkdownIt.disable(list, ignoreInvalid)</li></ul></li></ul><ul class="arguments"><li><ul class="argument"><li class="argument-name">list</li><li><ul class="argument-types"><li class="argument-type">String</li><li class="argument-type">Array</li></ul></li><li class="argument-description"><p>rule name or list of rule names to disable.</p>
|
||
|
</li></ul></li><li><ul class="argument"><li class="argument-name">ignoreInvalid</li><li><ul class="argument-types"><li class="argument-type">Boolean</li></ul></li><li class="argument-description"><p>set <code>true</code> to ignore errors when rule not found.</p>
|
||
|
</li></ul></li></ul><p>The same as <a href="#MarkdownIt.enable" class="link-short" title="MarkdownIt.enable (class method)" data-id="markdownit.enable">MarkdownIt.enable</a>, but turn specified rules off.</p>
|
||
|
</div></div></article><article class="docblock" id="MarkdownIt.enable" data-title="MarkdownIt.enable (class method)"><header><ul class="breadcrumbs"><li><a href="#home">Home</a></li><li><a href="#MarkdownIt" class="" title="MarkdownIt (class)" data-id="markdownit">MarkdownIt</a></li><li><a href="#MarkdownIt.enable" class="" title="MarkdownIt.enable (class method)" data-id="markdownit.enable">enable</a></li></ul><h2 title="class method"><span class="name_prefix">MarkdownIt.</span>enable</h2><div class="source"><a href="https://github.com/markdown-it/markdown-it/blob/0fe7cc/lib/index.mjs#L421">View source</a></div><div class="labels"><span class="chainable">chainable</span></div></header><div class="section method"><div class="content"><ul class="signatures"><li><ul class="signature"><li class="signature-call">MarkdownIt.enable(list, ignoreInvalid)</li></ul></li></ul><ul class="arguments"><li><ul class="argument"><li class="argument-name">list</li><li><ul class="argument-types"><li class="argument-type">String</li><li class="argument-type">Array</li></ul></li><li class="argument-description"><p>rule name or list of rule names to enable</p>
|
||
|
</li></ul></li><li><ul class="argument"><li class="argument-name">ignoreInvalid</li><li><ul class="argument-types"><li class="argument-type">Boolean</li></ul></li><li class="argument-description"><p>set <code>true</code> to ignore errors when rule not found.</p>
|
||
|
</li></ul></li></ul><p>Enable list or rules. It will automatically find appropriate components,
|
||
|
containing rules with given names. If rule not found, and <code>ignoreInvalid</code>
|
||
|
not set - throws exception.</p>
|
||
|
<h5>Example</h5>
|
||
|
<pre class="hljs language-javascript"><code><span class="hljs-keyword">var</span> md = <span class="hljs-built_in">require</span>(<span class="hljs-string">'markdown-it'</span>)()
|
||
|
.<span class="hljs-title function_">enable</span>([<span class="hljs-string">'sub'</span>, <span class="hljs-string">'sup'</span>])
|
||
|
.<span class="hljs-title function_">disable</span>(<span class="hljs-string">'smartquotes'</span>);
|
||
|
</code></pre>
|
||
|
</div></div></article><article class="docblock" id="MarkdownIt.parse" data-title="MarkdownIt.parse (class method)"><header><ul class="breadcrumbs"><li><a href="#home">Home</a></li><li><a href="#MarkdownIt" class="" title="MarkdownIt (class)" data-id="markdownit">MarkdownIt</a></li><li><a href="#MarkdownIt.parse" class="" title="MarkdownIt.parse (class method)" data-id="markdownit.parse">parse</a></li></ul><h2 title="class method"><span class="name_prefix">MarkdownIt.</span>parse</h2><div class="source"><a href="https://github.com/markdown-it/markdown-it/blob/0fe7cc/lib/index.mjs#L504">View source</a></div><div class="labels"><span class="internal">internal</span></div></header><div class="section method"><div class="content"><ul class="signatures"><li><ul class="signature"><li class="signature-call">MarkdownIt.parse(src, env)</li><li><ul class="signature-values"><li>Array</li></ul></li></ul></li></ul><ul class="arguments"><li><ul class="argument"><li class="argument-name">src</li><li><ul class="argument-types"><li class="argument-type">String</li></ul></li><li class="argument-description"><p>source string</p>
|
||
|
</li></ul></li><li><ul class="argument"><li class="argument-name">env</li><li><ul class="argument-types"><li class="argument-type">Object</li></ul></li><li class="argument-description"><p>environment sandbox</p>
|
||
|
</li></ul></li></ul><p>Parse input string and return list of block tokens (special token type
|
||
|
"inline" will contain list of inline tokens). You should not call this
|
||
|
method directly, until you write custom renderer (for example, to produce
|
||
|
AST).</p>
|
||
|
<p><code>env</code> is used to pass data between "distributed" rules and return additional
|
||
|
metadata like reference info, needed for the renderer. It also can be used to
|
||
|
inject data in specific cases. Usually, you will be ok to pass <code>{}</code>,
|
||
|
and then pass updated object to renderer.</p>
|
||
|
</div></div></article><article class="docblock" id="MarkdownIt.parseInline" data-title="MarkdownIt.parseInline (class method)"><header><ul class="breadcrumbs"><li><a href="#home">Home</a></li><li><a href="#MarkdownIt" class="" title="MarkdownIt (class)" data-id="markdownit">MarkdownIt</a></li><li><a href="#MarkdownIt.parseInline" class="" title="MarkdownIt.parseInline (class method)" data-id="markdownit.parseinline">parseInline</a></li></ul><h2 title="class method"><span class="name_prefix">MarkdownIt.</span>parseInline</h2><div class="source"><a href="https://github.com/markdown-it/markdown-it/blob/0fe7cc/lib/index.mjs#L542">View source</a></div><div class="labels"><span class="internal">internal</span></div></header><div class="section method"><div class="content"><ul class="signatures"><li><ul class="signature"><li class="signature-call">MarkdownIt.parseInline(src, env)</li><li><ul class="signature-values"><li>Array</li></ul></li></ul></li></ul><ul class="arguments"><li><ul class="argument"><li class="argument-name">src</li><li><ul class="argument-types"><li class="argument-type">String</li></ul></li><li class="argument-description"><p>source string</p>
|
||
|
</li></ul></li><li><ul class="argument"><li class="argument-name">env</li><li><ul class="argument-types"><li class="argument-type">Object</li></ul></li><li class="argument-description"><p>environment sandbox</p>
|
||
|
</li></ul></li></ul><p>The same as <a href="#MarkdownIt.parse" class="link-short" title="MarkdownIt.parse (class method)" data-id="markdownit.parse">MarkdownIt.parse</a> but skip all block rules. It returns the
|
||
|
block tokens list with the single <code>inline</code> element, containing parsed inline
|
||
|
tokens in <code>children</code> property. Also updates <code>env</code> object.</p>
|
||
|
</div></div></article><article class="docblock" id="MarkdownIt.render" data-title="MarkdownIt.render (class method)"><header><ul class="breadcrumbs"><li><a href="#home">Home</a></li><li><a href="#MarkdownIt" class="" title="MarkdownIt (class)" data-id="markdownit">MarkdownIt</a></li><li><a href="#MarkdownIt.render" class="" title="MarkdownIt.render (class method)" data-id="markdownit.render">render</a></li></ul><h2 title="class method"><span class="name_prefix">MarkdownIt.</span>render</h2><div class="source"><a href="https://github.com/markdown-it/markdown-it/blob/0fe7cc/lib/index.mjs#L527">View source</a></div></header><div class="section method"><div class="content"><ul class="signatures"><li><ul class="signature"><li class="signature-call">MarkdownIt.render(src[, env])</li><li><ul class="signature-values"><li>String</li></ul></li></ul></li></ul><ul class="arguments"><li><ul class="argument"><li class="argument-name">src</li><li><ul class="argument-types"><li class="argument-type">String</li></ul></li><li class="argument-description"><p>source string</p>
|
||
|
</li></ul></li><li><ul class="argument"><li class="argument-name">env</li><li><ul class="argument-types"><li class="argument-type">Object</li></ul></li><li class="argument-description"><p>environment sandbox</p>
|
||
|
</li></ul></li></ul><p>Render markdown string into html. It does all magic for you :).</p>
|
||
|
<p><code>env</code> can be used to inject additional metadata (<code>{}</code> by default).
|
||
|
But you will not need it with high probability. See also comment
|
||
|
in <a href="#MarkdownIt.parse" class="link-short" title="MarkdownIt.parse (class method)" data-id="markdownit.parse">MarkdownIt.parse</a>.</p>
|
||
|
</div></div></article><article class="docblock" id="MarkdownIt.renderInline" data-title="MarkdownIt.renderInline (class method)"><header><ul class="breadcrumbs"><li><a href="#home">Home</a></li><li><a href="#MarkdownIt" class="" title="MarkdownIt (class)" data-id="markdownit">MarkdownIt</a></li><li><a href="#MarkdownIt.renderInline" class="" title="MarkdownIt.renderInline (class method)" data-id="markdownit.renderinline">renderInline</a></li></ul><h2 title="class method"><span class="name_prefix">MarkdownIt.</span>renderInline</h2><div class="source"><a href="https://github.com/markdown-it/markdown-it/blob/0fe7cc/lib/index.mjs#L559">View source</a></div></header><div class="section method"><div class="content"><ul class="signatures"><li><ul class="signature"><li class="signature-call">MarkdownIt.renderInline(src[, env])</li><li><ul class="signature-values"><li>String</li></ul></li></ul></li></ul><ul class="arguments"><li><ul class="argument"><li class="argument-name">src</li><li><ul class="argument-types"><li class="argument-type">String</li></ul></li><li class="argument-description"><p>source string</p>
|
||
|
</li></ul></li><li><ul class="argument"><li class="argument-name">env</li><li><ul class="argument-types"><li class="argument-type">Object</li></ul></li><li class="argument-description"><p>environment sandbox</p>
|
||
|
</li></ul></li></ul><p>Similar to <a href="#MarkdownIt.render" class="link-short" title="MarkdownIt.render (class method)" data-id="markdownit.render">MarkdownIt.render</a> but for single paragraph content. Result
|
||
|
will NOT be wrapped into <code><p></code> tags.</p>
|
||
|
</div></div></article><article class="docblock" id="MarkdownIt.set" data-title="MarkdownIt.set (class method)"><header><ul class="breadcrumbs"><li><a href="#home">Home</a></li><li><a href="#MarkdownIt" class="" title="MarkdownIt (class)" data-id="markdownit">MarkdownIt</a></li><li><a href="#MarkdownIt.set" class="" title="MarkdownIt.set (class method)" data-id="markdownit.set">set</a></li></ul><h2 title="class method"><span class="name_prefix">MarkdownIt.</span>set</h2><div class="source"><a href="https://github.com/markdown-it/markdown-it/blob/0fe7cc/lib/index.mjs#L363">View source</a></div><div class="labels"><span class="chainable">chainable</span></div></header><div class="section method"><div class="content"><ul class="signatures"><li><ul class="signature"><li class="signature-call">MarkdownIt.set(options)</li></ul></li></ul><p>Set parser options (in the same format as in constructor). Probably, you
|
||
|
will never need it, but you can change options after constructor call.</p>
|
||
|
<h5>Example</h5>
|
||
|
<pre class="hljs language-javascript"><code><span class="hljs-keyword">var</span> md = <span class="hljs-built_in">require</span>(<span class="hljs-string">'markdown-it'</span>)()
|
||
|
.<span class="hljs-title function_">set</span>({ <span class="hljs-attr">html</span>: <span class="hljs-literal">true</span>, <span class="hljs-attr">breaks</span>: <span class="hljs-literal">true</span> })
|
||
|
.<span class="hljs-title function_">set</span>({ typographer, <span class="hljs-literal">true</span> });
|
||
|
</code></pre>
|
||
|
<p><strong>Note:</strong> To achieve the best possible performance, don't modify a
|
||
|
<code>markdown-it</code> instance options on the fly. If you need multiple configurations
|
||
|
it's best to create multiple instances and initialize each with separate
|
||
|
config.</p>
|
||
|
</div></div></article><article class="docblock" id="MarkdownIt.use" data-title="MarkdownIt.use (class method)"><header><ul class="breadcrumbs"><li><a href="#home">Home</a></li><li><a href="#MarkdownIt" class="" title="MarkdownIt (class)" data-id="markdownit">MarkdownIt</a></li><li><a href="#MarkdownIt.use" class="" title="MarkdownIt.use (class method)" data-id="markdownit.use">use</a></li></ul><h2 title="class method"><span class="name_prefix">MarkdownIt.</span>use</h2><div class="source"><a href="https://github.com/markdown-it/markdown-it/blob/0fe7cc/lib/index.mjs#L483">View source</a></div><div class="labels"><span class="chainable">chainable</span></div></header><div class="section method"><div class="content"><ul class="signatures"><li><ul class="signature"><li class="signature-call">MarkdownIt.use(plugin, params)</li></ul></li></ul><p>Load specified plugin with given params into current parser instance.
|
||
|
It's just a sugar to call <code>plugin(md, params)</code> with curring.</p>
|
||
|
<h5>Example</h5>
|
||
|
<pre class="hljs language-javascript"><code><span class="hljs-keyword">var</span> iterator = <span class="hljs-built_in">require</span>(<span class="hljs-string">'markdown-it-for-inline'</span>);
|
||
|
<span class="hljs-keyword">var</span> md = <span class="hljs-built_in">require</span>(<span class="hljs-string">'markdown-it'</span>)()
|
||
|
.<span class="hljs-title function_">use</span>(iterator, <span class="hljs-string">'foo_replace'</span>, <span class="hljs-string">'text'</span>, <span class="hljs-keyword">function</span> (<span class="hljs-params">tokens, idx</span>) {
|
||
|
tokens[idx].<span class="hljs-property">content</span> = tokens[idx].<span class="hljs-property">content</span>.<span class="hljs-title function_">replace</span>(<span class="hljs-regexp">/foo/g</span>, <span class="hljs-string">'bar'</span>);
|
||
|
});
|
||
|
</code></pre>
|
||
|
</div></div></article><article class="docblock" id="MarkdownIt.prototype.normalizeLink" data-title="MarkdownIt#normalizeLink (instance method)"><header><ul class="breadcrumbs"><li><a href="#home">Home</a></li><li><a href="#MarkdownIt" class="" title="MarkdownIt (class)" data-id="markdownit">MarkdownIt</a></li><li><a href="#MarkdownIt.prototype.normalizeLink" class="" title="MarkdownIt#normalizeLink (instance method)" data-id="markdownit#normalizelink">normalizeLink</a></li></ul><h2 title="instance method"><span class="name_prefix">MarkdownIt#</span>normalizeLink</h2><div class="source"><a href="https://github.com/markdown-it/markdown-it/blob/0fe7cc/lib/index.mjs#L311">View source</a></div></header><div class="section method"><div class="content"><ul class="signatures"><li><ul class="signature"><li class="signature-call">MarkdownIt#normalizeLink(url)</li><li><ul class="signature-values"><li>String</li></ul></li></ul></li></ul><p>Function used to encode link url to a machine-readable format,
|
||
|
which includes url-encoding, punycode, etc.</p>
|
||
|
</div></div></article><article class="docblock" id="MarkdownIt.prototype.normalizeLinkText" data-title="MarkdownIt#normalizeLinkText (instance method)"><header><ul class="breadcrumbs"><li><a href="#home">Home</a></li><li><a href="#MarkdownIt" class="" title="MarkdownIt (class)" data-id="markdownit">MarkdownIt</a></li><li><a href="#MarkdownIt.prototype.normalizeLinkText" class="" title="MarkdownIt#normalizeLinkText (instance method)" data-id="markdownit#normalizelinktext">normalizeLinkText</a></li></ul><h2 title="instance method"><span class="name_prefix">MarkdownIt#</span>normalizeLinkText</h2><div class="source"><a href="https://github.com/markdown-it/markdown-it/blob/0fe7cc/lib/index.mjs#L318">View source</a></div></header><div class="section method"><div class="content"><ul class="signatures"><li><ul class="signature"><li class="signature-call">MarkdownIt#normalizeLinkText(url)</li><li><ul class="signature-values"><li>String</li></ul></li></ul></li></ul><p>Function used to decode link url to a human-readable format`</p>
|
||
|
</div></div></article><article class="docblock" id="MarkdownIt.prototype.validateLink" data-title="MarkdownIt#validateLink (instance method)"><header><ul class="breadcrumbs"><li><a href="#home">Home</a></li><li><a href="#MarkdownIt" class="" title="MarkdownIt (class)" data-id="markdownit">MarkdownIt</a></li><li><a href="#MarkdownIt.prototype.validateLink" class="" title="MarkdownIt#validateLink (instance method)" data-id="markdownit#validatelink">validateLink</a></li></ul><h2 title="instance method"><span class="name_prefix">MarkdownIt#</span>validateLink</h2><div class="source"><a href="https://github.com/markdown-it/markdown-it/blob/0fe7cc/lib/index.mjs#L303">View source</a></div></header><div class="section method"><div class="content"><ul class="signatures"><li><ul class="signature"><li class="signature-call">MarkdownIt#validateLink(url)</li><li><ul class="signature-values"><li>Boolean</li></ul></li></ul></li></ul><p>Link validation function. CommonMark allows too much in links. By default
|
||
|
we disable <code>javascript:</code>, <code>vbscript:</code>, <code>file:</code> schemas, and almost all <code>data:...</code> schemas
|
||
|
except some embedded image types.</p>
|
||
|
<p>You can change this behaviour:</p>
|
||
|
<pre class="hljs language-javascript"><code><span class="hljs-keyword">var</span> md = <span class="hljs-built_in">require</span>(<span class="hljs-string">'markdown-it'</span>)();
|
||
|
<span class="hljs-comment">// enable everything</span>
|
||
|
md.<span class="hljs-property">validateLink</span> = <span class="hljs-keyword">function</span> (<span class="hljs-params"></span>) { <span class="hljs-keyword">return</span> <span class="hljs-literal">true</span>; }
|
||
|
</code></pre>
|
||
|
</div></div></article><article class="docblock" id="MarkdownIt.prototype.block" data-title="MarkdownIt#block (instance property)"><header><ul class="breadcrumbs"><li><a href="#home">Home</a></li><li><a href="#MarkdownIt" class="" title="MarkdownIt (class)" data-id="markdownit">MarkdownIt</a></li><li><a href="#MarkdownIt.prototype.block" class="" title="MarkdownIt#block (instance property)" data-id="markdownit#block">block</a></li></ul><h2 title="instance property"><span class="name_prefix">MarkdownIt#</span>block</h2><div class="source"><a href="https://github.com/markdown-it/markdown-it/blob/0fe7cc/lib/index.mjs#L245">View source</a></div></header><div class="section method"><div class="content"><ul class="signatures"><li><ul class="signature"><li class="signature-call">MarkdownIt#block</li><li><ul class="signature-values"><li><a href="#ParserBlock" class="link-short" title="ParserBlock (class)" data-id="parserblock">ParserBlock</a></li></ul></li></ul></li></ul><p>Instance of <a href="#ParserBlock" class="link-short" title="ParserBlock (class)" data-id="parserblock">ParserBlock</a>. You may need it to add new rules when
|
||
|
writing plugins. For simple rules control use <a href="#MarkdownIt.disable" class="link-short" title="MarkdownIt.disable (class method)" data-id="markdownit.disable">MarkdownIt.disable</a> and
|
||
|
<a href="#MarkdownIt.enable" class="link-short" title="MarkdownIt.enable (class method)" data-id="markdownit.enable">MarkdownIt.enable</a>.</p>
|
||
|
</div></div></article><article class="docblock" id="MarkdownIt.prototype.core" data-title="MarkdownIt#core (instance property)"><header><ul class="breadcrumbs"><li><a href="#home">Home</a></li><li><a href="#MarkdownIt" class="" title="MarkdownIt (class)" data-id="markdownit">MarkdownIt</a></li><li><a href="#MarkdownIt.prototype.core" class="" title="MarkdownIt#core (instance property)" data-id="markdownit#core">core</a></li></ul><h2 title="instance property"><span class="name_prefix">MarkdownIt#</span>core</h2><div class="source"><a href="https://github.com/markdown-it/markdown-it/blob/0fe7cc/lib/index.mjs#L254">View source</a></div></header><div class="section method"><div class="content"><ul class="signatures"><li><ul class="signature"><li class="signature-call">MarkdownIt#core</li><li><ul class="signature-values"><li><a href="#Core" class="link-short" title="Core (class)" data-id="core">Core</a></li></ul></li></ul></li></ul><p>Instance of <a href="#Core" class="link-short" title="Core (class)" data-id="core">Core</a> chain executor. You may need it to add new rules when
|
||
|
writing plugins. For simple rules control use <a href="#MarkdownIt.disable" class="link-short" title="MarkdownIt.disable (class method)" data-id="markdownit.disable">MarkdownIt.disable</a> and
|
||
|
<a href="#MarkdownIt.enable" class="link-short" title="MarkdownIt.enable (class method)" data-id="markdownit.enable">MarkdownIt.enable</a>.</p>
|
||
|
</div></div></article><article class="docblock" id="MarkdownIt.prototype.helpers" data-title="MarkdownIt#helpers (instance property)"><header><ul class="breadcrumbs"><li><a href="#home">Home</a></li><li><a href="#MarkdownIt" class="" title="MarkdownIt (class)" data-id="markdownit">MarkdownIt</a></li><li><a href="#MarkdownIt.prototype.helpers" class="" title="MarkdownIt#helpers (instance property)" data-id="markdownit#helpers">helpers</a></li></ul><h2 title="instance property"><span class="name_prefix">MarkdownIt#</span>helpers</h2><div class="source"><a href="https://github.com/markdown-it/markdown-it/blob/0fe7cc/lib/index.mjs#L336">View source</a></div></header><div class="section method"><div class="content"><ul class="signatures"><li><ul class="signature"><li class="signature-call">MarkdownIt#helpers</li><li><ul class="signature-values"><li>helpers</li></ul></li></ul></li></ul><p>Link components parser functions, useful to write plugins. See details
|
||
|
<a href="https://github.com/markdown-it/markdown-it/blob/master/lib/helpers">here</a>.</p>
|
||
|
</div></div></article><article class="docblock" id="MarkdownIt.prototype.inline" data-title="MarkdownIt#inline (instance property)"><header><ul class="breadcrumbs"><li><a href="#home">Home</a></li><li><a href="#MarkdownIt" class="" title="MarkdownIt (class)" data-id="markdownit">MarkdownIt</a></li><li><a href="#MarkdownIt.prototype.inline" class="" title="MarkdownIt#inline (instance property)" data-id="markdownit#inline">inline</a></li></ul><h2 title="instance property"><span class="name_prefix">MarkdownIt#</span>inline</h2><div class="source"><a href="https://github.com/markdown-it/markdown-it/blob/0fe7cc/lib/index.mjs#L236">View source</a></div></header><div class="section method"><div class="content"><ul class="signatures"><li><ul class="signature"><li class="signature-call">MarkdownIt#inline</li><li><ul class="signature-values"><li><a href="#ParserInline" class="link-short" title="ParserInline (class)" data-id="parserinline">ParserInline</a></li></ul></li></ul></li></ul><p>Instance of <a href="#ParserInline" class="link-short" title="ParserInline (class)" data-id="parserinline">ParserInline</a>. You may need it to add new rules when
|
||
|
writing plugins. For simple rules control use <a href="#MarkdownIt.disable" class="link-short" title="MarkdownIt.disable (class method)" data-id="markdownit.disable">MarkdownIt.disable</a> and
|
||
|
<a href="#MarkdownIt.enable" class="link-short" title="MarkdownIt.enable (class method)" data-id="markdownit.enable">MarkdownIt.enable</a>.</p>
|
||
|
</div></div></article><article class="docblock" id="MarkdownIt.prototype.linkify" data-title="MarkdownIt#linkify (instance property)"><header><ul class="breadcrumbs"><li><a href="#home">Home</a></li><li><a href="#MarkdownIt" class="" title="MarkdownIt (class)" data-id="markdownit">MarkdownIt</a></li><li><a href="#MarkdownIt.prototype.linkify" class="" title="MarkdownIt#linkify (instance property)" data-id="markdownit#linkify">linkify</a></li></ul><h2 title="instance property"><span class="name_prefix">MarkdownIt#</span>linkify</h2><div class="source"><a href="https://github.com/markdown-it/markdown-it/blob/0fe7cc/lib/index.mjs#L286">View source</a></div></header><div class="section method"><div class="content"><ul class="signatures"><li><ul class="signature"><li class="signature-call">MarkdownIt#linkify</li><li><ul class="signature-values"><li>LinkifyIt</li></ul></li></ul></li></ul><p><a href="https://github.com/markdown-it/linkify-it">linkify-it</a> instance.
|
||
|
Used by <a href="https://github.com/markdown-it/markdown-it/blob/master/lib/rules_core/linkify.mjs">linkify</a>
|
||
|
rule.</p>
|
||
|
</div></div></article><article class="docblock" id="MarkdownIt.prototype.renderer" data-title="MarkdownIt#renderer (instance property)"><header><ul class="breadcrumbs"><li><a href="#home">Home</a></li><li><a href="#MarkdownIt" class="" title="MarkdownIt (class)" data-id="markdownit">MarkdownIt</a></li><li><a href="#MarkdownIt.prototype.renderer" class="" title="MarkdownIt#renderer (instance property)" data-id="markdownit#renderer">renderer</a></li></ul><h2 title="instance property"><span class="name_prefix">MarkdownIt#</span>renderer</h2><div class="source"><a href="https://github.com/markdown-it/markdown-it/blob/0fe7cc/lib/index.mjs#L277">View source</a></div></header><div class="section method"><div class="content"><ul class="signatures"><li><ul class="signature"><li class="signature-call">MarkdownIt#renderer</li><li><ul class="signature-values"><li><a href="#Renderer" class="link-short" title="Renderer (class)" data-id="renderer">Renderer</a></li></ul></li></ul></li></ul><p>Instance of <a href="#Renderer" class="link-short" title="Renderer (class)" data-id="renderer">Renderer</a>. Use it to modify output look. Or to add rendering
|
||
|
rules for new token types, generated by plugins.</p>
|
||
|
<h5>Example</h5>
|
||
|
<pre class="hljs language-javascript"><code><span class="hljs-keyword">var</span> md = <span class="hljs-built_in">require</span>(<span class="hljs-string">'markdown-it'</span>)();
|
||
|
|
||
|
<span class="hljs-keyword">function</span> <span class="hljs-title function_">myToken</span>(<span class="hljs-params">tokens, idx, options, env, self</span>) {
|
||
|
<span class="hljs-comment">//...</span>
|
||
|
<span class="hljs-keyword">return</span> result;
|
||
|
};
|
||
|
|
||
|
md.<span class="hljs-property">renderer</span>.<span class="hljs-property">rules</span>[<span class="hljs-string">'my_token'</span>] = myToken
|
||
|
</code></pre>
|
||
|
<p>See <a href="#Renderer" class="link-short" title="Renderer (class)" data-id="renderer">Renderer</a> docs and <a href="https://github.com/markdown-it/markdown-it/blob/master/lib/renderer.mjs">source code</a>.</p>
|
||
|
</div></div></article><article class="docblock" id="MarkdownIt.prototype.utils" data-title="MarkdownIt#utils (instance property)"><header><ul class="breadcrumbs"><li><a href="#home">Home</a></li><li><a href="#MarkdownIt" class="" title="MarkdownIt (class)" data-id="markdownit">MarkdownIt</a></li><li><a href="#MarkdownIt.prototype.utils" class="" title="MarkdownIt#utils (instance property)" data-id="markdownit#utils">utils</a></li></ul><h2 title="instance property"><span class="name_prefix">MarkdownIt#</span>utils</h2><div class="source"><a href="https://github.com/markdown-it/markdown-it/blob/0fe7cc/lib/index.mjs#L328">View source</a></div></header><div class="section method"><div class="content"><ul class="signatures"><li><ul class="signature"><li class="signature-call">MarkdownIt#utils</li><li><ul class="signature-values"><li>utils</li></ul></li></ul></li></ul><p>Assorted utility functions, useful to write plugins. See details
|
||
|
<a href="https://github.com/markdown-it/markdown-it/blob/master/lib/common/utils.mjs">here</a>.</p>
|
||
|
</div></div></article><article class="docblock" id="ParserBlock" data-title="ParserBlock (class)"><header><ul class="breadcrumbs"><li><a href="#home">Home</a></li><li><a href="#ParserBlock" class="" title="ParserBlock (class)" data-id="parserblock">ParserBlock</a></li></ul><h2 title="class">ParserBlock</h2><div class="source"><a href="https://github.com/markdown-it/markdown-it/blob/0fe7cc/lib/parser_block.mjs#L6">View source</a></div><div class="labels"><span class="internal">internal</span></div></header><div class="section description"><h3>Description</h3><div class="content"><p>Block-level tokenizer.</p>
|
||
|
</div></div><div class="section constructor"><h3>Constructor</h3><div class="content"></div><ul class="method-list"><li><a href="#ParserBlock.new" class="" title="new ParserBlock (constructor)" data-id="new parserblock">new ParserBlock</a></li></ul></div><div class="section class_methods"><h3>Class methods</h3><div class="content"><ul class="method-list"><li><a href="#ParserBlock.parse" class="" title="ParserBlock.parse (class method)" data-id="parserblock.parse">parse</a></li></ul></div></div><div class="section instance_properties"><h3>Instance properties</h3><div class="content"><ul class="method-list"><li><a href="#ParserBlock.prototype.ruler" class="" title="ParserBlock#ruler (instance property)" data-id="parserblock#ruler">ruler</a></li></ul></div></div></article><article class="docblock" id="ParserBlock.new" data-title="new ParserBlock (constructor)"><header><ul class="breadcrumbs"><li><a href="#home">Home</a></li><li><a href="#ParserBlock" class="" title="ParserBlock (class)" data-id="parserblock">ParserBlock</a></li><li><a href="#ParserBlock.new" class="" title="new ParserBlock (constructor)" data-id="new parserblock">new</a></li></ul><h2 title="constructor"><span class="name_prefix">ParserBlock.</span>new</h2><div class="source"><a href="https://github.com/markdown-it/markdown-it/blob/0fe7cc/lib/parser_block.mjs#L41">View source</a></div></header><div class="section method"><div class="content"><ul class="signatures"><li><ul class="signature"><li class="signature-call">new ParserBlock()</li></ul></li></ul></div></div></article><article class="docblock" id="ParserBlock.parse" data-title="ParserBlock.parse (class method)"><header><ul class="breadcrumbs"><li><a href="#home">Home</a></li><li><a href="#ParserBlock" class="" title="ParserBlock (class)" data-id="parserblock">ParserBlock</a></li><li><a href="#ParserBlock.parse" class="" title="ParserBlock.parse (class method)" data-id="parserblock.parse">parse</a></li></ul><h2 title="class method"><span class="name_prefix">ParserBlock.</span>parse</h2><div class="source"><a href="https://github.com/markdown-it/markdown-it/blob/0fe7cc/lib/parser_block.mjs#L124">View source</a></div></header><div class="section method"><div class="content"><ul class="signatures"><li><ul class="signature"><li class="signature-call">ParserBlock.parse(str, md, env, outTokens)</li></ul></li></ul><p>Process input string and push block tokens into <code>outTokens</code></p>
|
||
|
</div></div></article><article class="docblock" id="ParserBlock.prototype.ruler" data-title="ParserBlock#ruler (instance property)"><header><ul class="breadcrumbs"><li><a href="#home">Home</a></li><li><a href="#ParserBlock" class="" title="ParserBlock (class)" data-id="parserblock">ParserBlock</a></li><li><a href="#ParserBlock.prototype.ruler" class="" title="ParserBlock#ruler (instance property)" data-id="parserblock#ruler">ruler</a></li></ul><h2 title="instance property"><span class="name_prefix">ParserBlock#</span>ruler</h2><div class="source"><a href="https://github.com/markdown-it/markdown-it/blob/0fe7cc/lib/parser_block.mjs#L47">View source</a></div></header><div class="section method"><div class="content"><ul class="signatures"><li><ul class="signature"><li class="signature-call">ParserBlock#ruler</li><li><ul class="signature-values"><li><a href="#Ruler" class="link-short" title="Ruler (class)" data-id="ruler">Ruler</a></li></ul></li></ul></li></ul><p><a href="#Ruler" class="link-short" title="Ruler (class)" data-id="ruler">Ruler</a> instance. Keep configuration of block rules.</p>
|
||
|
</div></div></article><article class="docblock" id="ParserInline" data-title="ParserInline (class)"><header><ul class="breadcrumbs"><li><a href="#home">Home</a></li><li><a href="#ParserInline" class="" title="ParserInline (class)" data-id="parserinline">ParserInline</a></li></ul><h2 title="class">ParserInline</h2><div class="source"><a href="https://github.com/markdown-it/markdown-it/blob/0fe7cc/lib/parser_inline.mjs#L6">View source</a></div><div class="labels"><span class="internal">internal</span></div></header><div class="section description"><h3>Description</h3><div class="content"><p>Tokenizes paragraph content.</p>
|
||
|
</div></div><div class="section constructor"><h3>Constructor</h3><div class="content"></div><ul class="method-list"><li><a href="#ParserInline.new" class="" title="new ParserInline (constructor)" data-id="new parserinline">new ParserInline</a></li></ul></div><div class="section class_methods"><h3>Class methods</h3><div class="content"><ul class="method-list"><li><a href="#ParserInline.parse" class="" title="ParserInline.parse (class method)" data-id="parserinline.parse">parse</a></li></ul></div></div><div class="section instance_properties"><h3>Instance properties</h3><div class="content"><ul class="method-list"><li><a href="#ParserInline.prototype.ruler" class="" title="ParserInline#ruler (instance property)" data-id="parserinline#ruler">ruler</a></li><li><a href="#ParserInline.prototype.ruler2" class="" title="ParserInline#ruler2 (instance property)" data-id="parserinline#ruler2">ruler2</a></li></ul></div></div></article><article class="docblock" id="ParserInline.new" data-title="new ParserInline (constructor)"><header><ul class="breadcrumbs"><li><a href="#home">Home</a></li><li><a href="#ParserInline" class="" title="ParserInline (class)" data-id="parserinline">ParserInline</a></li><li><a href="#ParserInline.new" class="" title="new ParserInline (constructor)" data-id="new parserinline">new</a></li></ul><h2 title="constructor"><span class="name_prefix">ParserInline.</span>new</h2><div class="source"><a href="https://github.com/markdown-it/markdown-it/blob/0fe7cc/lib/parser_inline.mjs#L60">View source</a></div></header><div class="section method"><div class="content"><ul class="signatures"><li><ul class="signature"><li class="signature-call">new ParserInline()</li></ul></li></ul></div></div></article><article class="docblock" id="ParserInline.parse" data-title="ParserInline.parse (class method)"><header><ul class="breadcrumbs"><li><a href="#home">Home</a></li><li><a href="#ParserInline" class="" title="ParserInline (class)" data-id="parserinline">ParserInline</a></li><li><a href="#ParserInline.parse" class="" title="ParserInline.parse (class method)" data-id="parserinline.parse">parse</a></li></ul><h2 title="class method"><span class="name_prefix">ParserInline.</span>parse</h2><div class="source"><a href="https://github.com/markdown-it/markdown-it/blob/0fe7cc/lib/parser_inline.mjs#L182">View source</a></div></header><div class="section method"><div class="content"><ul class="signatures"><li><ul class="signature"><li class="signature-call">ParserInline.parse(str, md, env, outTokens)</li></ul></li></ul><p>Process input string and push inline tokens into <code>outTokens</code></p>
|
||
|
</div></div></article><article class="docblock" id="ParserInline.prototype.ruler" data-title="ParserInline#ruler (instance property)"><header><ul class="breadcrumbs"><li><a href="#home">Home</a></li><li><a href="#ParserInline" class="" title="ParserInline (class)" data-id="parserinline">ParserInline</a></li><li><a href="#ParserInline.prototype.ruler" class="" title="ParserInline#ruler (instance property)" data-id="parserinline#ruler">ruler</a></li></ul><h2 title="instance property"><span class="name_prefix">ParserInline#</span>ruler</h2><div class="source"><a href="https://github.com/markdown-it/markdown-it/blob/0fe7cc/lib/parser_inline.mjs#L66">View source</a></div></header><div class="section method"><div class="content"><ul class="signatures"><li><ul class="signature"><li class="signature-call">ParserInline#ruler</li><li><ul class="signature-values"><li><a href="#Ruler" class="link-short" title="Ruler (class)" data-id="ruler">Ruler</a></li></ul></li></ul></li></ul><p><a href="#Ruler" class="link-short" title="Ruler (class)" data-id="ruler">Ruler</a> instance. Keep configuration of inline rules.</p>
|
||
|
</div></div></article><article class="docblock" id="ParserInline.prototype.ruler2" data-title="ParserInline#ruler2 (instance property)"><header><ul class="breadcrumbs"><li><a href="#home">Home</a></li><li><a href="#ParserInline" class="" title="ParserInline (class)" data-id="parserinline">ParserInline</a></li><li><a href="#ParserInline.prototype.ruler2" class="" title="ParserInline#ruler2 (instance property)" data-id="parserinline#ruler2">ruler2</a></li></ul><h2 title="instance property"><span class="name_prefix">ParserInline#</span>ruler2</h2><div class="source"><a href="https://github.com/markdown-it/markdown-it/blob/0fe7cc/lib/parser_inline.mjs#L78">View source</a></div></header><div class="section method"><div class="content"><ul class="signatures"><li><ul class="signature"><li class="signature-call">ParserInline#ruler2</li><li><ul class="signature-values"><li><a href="#Ruler" class="link-short" title="Ruler (class)" data-id="ruler">Ruler</a></li></ul></li></ul></li></ul><p><a href="#Ruler" class="link-short" title="Ruler (class)" data-id="ruler">Ruler</a> instance. Second ruler used for post-processing
|
||
|
(e.g. in emphasis-like rules).</p>
|
||
|
</div></div></article><article class="docblock" id="Renderer" data-title="Renderer (class)"><header><ul class="breadcrumbs"><li><a href="#home">Home</a></li><li><a href="#Renderer" class="" title="Renderer (class)" data-id="renderer">Renderer</a></li></ul><h2 title="class">Renderer</h2><div class="source"><a href="https://github.com/markdown-it/markdown-it/blob/0fe7cc/lib/renderer.mjs#L8">View source</a></div></header><div class="section description"><h3>Description</h3><div class="content"><p>Generates HTML from parsed token stream. Each instance has independent
|
||
|
copy of rules. Those can be rewritten with ease. Also, you can add new
|
||
|
rules if you create plugin and adds new token types.</p>
|
||
|
</div></div><div class="section constructor"><h3>Constructor</h3><div class="content"></div><ul class="method-list"><li><a href="#Renderer.new" class="" title="new Renderer (constructor)" data-id="new renderer">new Renderer</a></li></ul></div><div class="section class_methods"><h3>Class methods</h3><div class="content"><ul class="method-list"><li><a href="#Renderer.render" class="" title="Renderer.render (class method)" data-id="renderer.render">render</a></li><li><a href="#Renderer.renderAttrs" class="" title="Renderer.renderAttrs (class method)" data-id="renderer.renderattrs">renderAttrs</a></li><li><a href="#Renderer.renderInline" class="" title="Renderer.renderInline (class method)" data-id="renderer.renderinline">renderInline</a></li><li><a href="#Renderer.renderInlineAsText" class="" title="Renderer.renderInlineAsText (class method)" data-id="renderer.renderinlineastext">renderInlineAsText</a></li><li><a href="#Renderer.renderToken" class="" title="Renderer.renderToken (class method)" data-id="renderer.rendertoken">renderToken</a></li></ul></div></div><div class="section instance_properties"><h3>Instance properties</h3><div class="content"><ul class="method-list"><li><a href="#Renderer.prototype.rules" class="" title="Renderer#rules (instance property)" data-id="renderer#rules">rules</a></li></ul></div></div></article><article class="docblock" id="Renderer.new" data-title="new Renderer (constructor)"><header><ul class="breadcrumbs"><li><a href="#home">Home</a></li><li><a href="#Renderer" class="" title="Renderer (class)" data-id="renderer">Renderer</a></li><li><a href="#Renderer.new" class="" title="new Renderer (constructor)" data-id="new renderer">new</a></li></ul><h2 title="constructor"><span class="name_prefix">Renderer.</span>new</h2><div class="source"><a href="https://github.com/markdown-it/markdown-it/blob/0fe7cc/lib/renderer.mjs#L114">View source</a></div></header><div class="section method"><div class="content"><ul class="signatures"><li><ul class="signature"><li class="signature-call">new Renderer()</li></ul></li></ul><p>Creates new <a href="#Renderer" class="link-short" title="Renderer (class)" data-id="renderer">Renderer</a> instance and fill <a href="#Renderer.prototype.rules" class="link-short" title="Renderer#rules (instance property)" data-id="renderer#rules">Renderer#rules</a> with defaults.</p>
|
||
|
</div></div></article><article class="docblock" id="Renderer.render" data-title="Renderer.render (class method)"><header><ul class="breadcrumbs"><li><a href="#home">Home</a></li><li><a href="#Renderer" class="" title="Renderer (class)" data-id="renderer">Renderer</a></li><li><a href="#Renderer.render" class="" title="Renderer.render (class method)" data-id="renderer.render">render</a></li></ul><h2 title="class method"><span class="name_prefix">Renderer.</span>render</h2><div class="source"><a href="https://github.com/markdown-it/markdown-it/blob/0fe7cc/lib/renderer.mjs#L303">View source</a></div></header><div class="section method"><div class="content"><ul class="signatures"><li><ul class="signature"><li class="signature-call">Renderer.render(tokens, options, env)</li><li><ul class="signature-values"><li>String</li></ul></li></ul></li></ul><ul class="arguments"><li><ul class="argument"><li class="argument-name">tokens</li><li><ul class="argument-types"><li class="argument-type">Array</li></ul></li><li class="argument-description"><p>list on block tokens to render</p>
|
||
|
</li></ul></li><li><ul class="argument"><li class="argument-name">options</li><li><ul class="argument-types"><li class="argument-type">Object</li></ul></li><li class="argument-description"><p>params of parser instance</p>
|
||
|
</li></ul></li><li><ul class="argument"><li class="argument-name">env</li><li><ul class="argument-types"><li class="argument-type">Object</li></ul></li><li class="argument-description"><p>additional data from parsed input (references, for example)</p>
|
||
|
</li></ul></li></ul><p>Takes token stream and generates HTML. Probably, you will never need to call
|
||
|
this method directly.</p>
|
||
|
</div></div></article><article class="docblock" id="Renderer.renderAttrs" data-title="Renderer.renderAttrs (class method)"><header><ul class="breadcrumbs"><li><a href="#home">Home</a></li><li><a href="#Renderer" class="" title="Renderer (class)" data-id="renderer">Renderer</a></li><li><a href="#Renderer.renderAttrs" class="" title="Renderer.renderAttrs (class method)" data-id="renderer.renderattrs">renderAttrs</a></li></ul><h2 title="class method"><span class="name_prefix">Renderer.</span>renderAttrs</h2><div class="source"><a href="https://github.com/markdown-it/markdown-it/blob/0fe7cc/lib/renderer.mjs#L151">View source</a></div></header><div class="section method"><div class="content"><ul class="signatures"><li><ul class="signature"><li class="signature-call">Renderer.renderAttrs(token)</li><li><ul class="signature-values"><li>String</li></ul></li></ul></li></ul><p>Render token attributes to string.</p>
|
||
|
</div></div></article><article class="docblock" id="Renderer.renderInline" data-title="Renderer.renderInline (class method)"><header><ul class="breadcrumbs"><li><a href="#home">Home</a></li><li><a href="#Renderer" class="" title="Renderer (class)" data-id="renderer">Renderer</a></li><li><a href="#Renderer.renderInline" class="" title="Renderer.renderInline (class method)" data-id="renderer.renderinline">renderInline</a></li></ul><h2 title="class method"><span class="name_prefix">Renderer.</span>renderInline</h2><div class="source"><a href="https://github.com/markdown-it/markdown-it/blob/0fe7cc/lib/renderer.mjs#L240">View source</a></div></header><div class="section method"><div class="content"><ul class="signatures"><li><ul class="signature"><li class="signature-call">Renderer.renderInline(tokens, options, env)</li><li><ul class="signature-values"><li>String</li></ul></li></ul></li></ul><ul class="arguments"><li><ul class="argument"><li class="argument-name">tokens</li><li><ul class="argument-types"><li class="argument-type">Array</li></ul></li><li class="argument-description"><p>list on block tokens to render</p>
|
||
|
</li></ul></li><li><ul class="argument"><li class="argument-name">options</li><li><ul class="argument-types"><li class="argument-type">Object</li></ul></li><li class="argument-description"><p>params of parser instance</p>
|
||
|
</li></ul></li><li><ul class="argument"><li class="argument-name">env</li><li><ul class="argument-types"><li class="argument-type">Object</li></ul></li><li class="argument-description"><p>additional data from parsed input (references, for example)</p>
|
||
|
</li></ul></li></ul><p>The same as <a href="#Renderer.render" class="link-short" title="Renderer.render (class method)" data-id="renderer.render">Renderer.render</a>, but for single token of <code>inline</code> type.</p>
|
||
|
</div></div></article><article class="docblock" id="Renderer.renderInlineAsText" data-title="Renderer.renderInlineAsText (class method)"><header><ul class="breadcrumbs"><li><a href="#home">Home</a></li><li><a href="#Renderer" class="" title="Renderer (class)" data-id="renderer">Renderer</a></li><li><a href="#Renderer.renderInlineAsText" class="" title="Renderer.renderInlineAsText (class method)" data-id="renderer.renderinlineastext">renderInlineAsText</a></li></ul><h2 title="class method"><span class="name_prefix">Renderer.</span>renderInlineAsText</h2><div class="source"><a href="https://github.com/markdown-it/markdown-it/blob/0fe7cc/lib/renderer.mjs#L267">View source</a></div><div class="labels"><span class="internal">internal</span></div></header><div class="section method"><div class="content"><ul class="signatures"><li><ul class="signature"><li class="signature-call">Renderer.renderInlineAsText(tokens, options, env)</li><li><ul class="signature-values"><li>String</li></ul></li></ul></li></ul><ul class="arguments"><li><ul class="argument"><li class="argument-name">tokens</li><li><ul class="argument-types"><li class="argument-type">Array</li></ul></li><li class="argument-description"><p>list on block tokens to render</p>
|
||
|
</li></ul></li><li><ul class="argument"><li class="argument-name">options</li><li><ul class="argument-types"><li class="argument-type">Object</li></ul></li><li class="argument-description"><p>params of parser instance</p>
|
||
|
</li></ul></li><li><ul class="argument"><li class="argument-name">env</li><li><ul class="argument-types"><li class="argument-type">Object</li></ul></li><li class="argument-description"><p>additional data from parsed input (references, for example)</p>
|
||
|
</li></ul></li></ul><p>Special kludge for image <code>alt</code> attributes to conform CommonMark spec.
|
||
|
Don't try to use it! Spec requires to show <code>alt</code> content with stripped markup,
|
||
|
instead of simple escaping.</p>
|
||
|
</div></div></article><article class="docblock" id="Renderer.renderToken" data-title="Renderer.renderToken (class method)"><header><ul class="breadcrumbs"><li><a href="#home">Home</a></li><li><a href="#Renderer" class="" title="Renderer (class)" data-id="renderer">Renderer</a></li><li><a href="#Renderer.renderToken" class="" title="Renderer.renderToken (class method)" data-id="renderer.rendertoken">renderToken</a></li></ul><h2 title="class method"><span class="name_prefix">Renderer.</span>renderToken</h2><div class="source"><a href="https://github.com/markdown-it/markdown-it/blob/0fe7cc/lib/renderer.mjs#L174">View source</a></div></header><div class="section method"><div class="content"><ul class="signatures"><li><ul class="signature"><li class="signature-call">Renderer.renderToken(tokens, idx, options)</li><li><ul class="signature-values"><li>String</li></ul></li></ul></li></ul><ul class="arguments"><li><ul class="argument"><li class="argument-name">tokens</li><li><ul class="argument-types"><li class="argument-type">Array</li></ul></li><li class="argument-description"><p>list of tokens</p>
|
||
|
</li></ul></li><li><ul class="argument"><li class="argument-name">idx</li><li><ul class="argument-types"><li class="argument-type">Numbed</li></ul></li><li class="argument-description"><p>token index to render</p>
|
||
|
</li></ul></li><li><ul class="argument"><li class="argument-name">options</li><li><ul class="argument-types"><li class="argument-type">Object</li></ul></li><li class="argument-description"><p>params of parser instance</p>
|
||
|
</li></ul></li></ul><p>Default token renderer. Can be overriden by custom function
|
||
|
in <a href="#Renderer.prototype.rules" class="link-short" title="Renderer#rules (instance property)" data-id="renderer#rules">Renderer#rules</a>.</p>
|
||
|
</div></div></article><article class="docblock" id="Renderer.prototype.rules" data-title="Renderer#rules (instance property)"><header><ul class="breadcrumbs"><li><a href="#home">Home</a></li><li><a href="#Renderer" class="" title="Renderer (class)" data-id="renderer">Renderer</a></li><li><a href="#Renderer.prototype.rules" class="" title="Renderer#rules (instance property)" data-id="renderer#rules">rules</a></li></ul><h2 title="instance property"><span class="name_prefix">Renderer#</span>rules</h2><div class="source"><a href="https://github.com/markdown-it/markdown-it/blob/0fe7cc/lib/renderer.mjs#L143">View source</a></div></header><div class="section method"><div class="content"><ul class="signatures"><li><ul class="signature"><li class="signature-call">Renderer#rules</li><li><ul class="signature-values"><li>Object</li></ul></li></ul></li></ul><p>Contains render rules for tokens. Can be updated and extended.</p>
|
||
|
<h5>Example</h5>
|
||
|
<pre class="hljs language-javascript"><code><span class="hljs-keyword">var</span> md = <span class="hljs-built_in">require</span>(<span class="hljs-string">'markdown-it'</span>)();
|
||
|
|
||
|
md.<span class="hljs-property">renderer</span>.<span class="hljs-property">rules</span>.<span class="hljs-property">strong_open</span> = <span class="hljs-keyword">function</span> (<span class="hljs-params"></span>) { <span class="hljs-keyword">return</span> <span class="hljs-string">'<b>'</span>; };
|
||
|
md.<span class="hljs-property">renderer</span>.<span class="hljs-property">rules</span>.<span class="hljs-property">strong_close</span> = <span class="hljs-keyword">function</span> (<span class="hljs-params"></span>) { <span class="hljs-keyword">return</span> <span class="hljs-string">'</b>'</span>; };
|
||
|
|
||
|
<span class="hljs-keyword">var</span> result = md.<span class="hljs-title function_">renderInline</span>(...);
|
||
|
</code></pre>
|
||
|
<p>Each rule is called as independent static function with fixed signature:</p>
|
||
|
<pre class="hljs language-javascript"><code><span class="hljs-keyword">function</span> <span class="hljs-title function_">my_token_render</span>(<span class="hljs-params">tokens, idx, options, env, renderer</span>) {
|
||
|
<span class="hljs-comment">// ...</span>
|
||
|
<span class="hljs-keyword">return</span> renderedHTML;
|
||
|
}
|
||
|
</code></pre>
|
||
|
<p>See <a href="https://github.com/markdown-it/markdown-it/blob/master/lib/renderer.mjs">source code</a>
|
||
|
for more details and examples.</p>
|
||
|
</div></div></article><article class="docblock" id="Ruler" data-title="Ruler (class)"><header><ul class="breadcrumbs"><li><a href="#home">Home</a></li><li><a href="#Ruler" class="" title="Ruler (class)" data-id="ruler">Ruler</a></li></ul><h2 title="class">Ruler</h2><div class="source"><a href="https://github.com/markdown-it/markdown-it/blob/0fe7cc/lib/ruler.mjs#L18">View source</a></div></header><div class="section description"><h3>Description</h3><div class="content"><p>Helper class, used by <a href="#MarkdownIt.prototype.core" class="link-short" title="MarkdownIt#core (instance property)" data-id="markdownit#core">MarkdownIt#core</a>, <a href="#MarkdownIt.prototype.block" class="link-short" title="MarkdownIt#block (instance property)" data-id="markdownit#block">MarkdownIt#block</a> and
|
||
|
<a href="#MarkdownIt.prototype.inline" class="link-short" title="MarkdownIt#inline (instance property)" data-id="markdownit#inline">MarkdownIt#inline</a> to manage sequences of functions (rules):</p>
|
||
|
<ul>
|
||
|
<li>keep rules in defined order</li>
|
||
|
<li>assign the name to each rule</li>
|
||
|
<li>enable/disable rules</li>
|
||
|
<li>add/replace rules</li>
|
||
|
<li>allow assign rules to additional named chains (in the same)</li>
|
||
|
<li>cacheing lists of active rules</li>
|
||
|
</ul>
|
||
|
<p>You will not need use this class directly until write plugins. For simple
|
||
|
rules control use <a href="#MarkdownIt.disable" class="link-short" title="MarkdownIt.disable (class method)" data-id="markdownit.disable">MarkdownIt.disable</a>, <a href="#MarkdownIt.enable" class="link-short" title="MarkdownIt.enable (class method)" data-id="markdownit.enable">MarkdownIt.enable</a> and
|
||
|
<a href="#MarkdownIt.use" class="link-short" title="MarkdownIt.use (class method)" data-id="markdownit.use">MarkdownIt.use</a>.</p>
|
||
|
</div></div><div class="section constructor"><h3>Constructor</h3><div class="content"></div><ul class="method-list"><li><a href="#Ruler.new" class="" title="new Ruler (constructor)" data-id="new ruler">new Ruler</a></li></ul></div><div class="section class_methods"><h3>Class methods</h3><div class="content"><ul class="method-list"><li><a href="#Ruler.after" class="" title="Ruler.after (class method)" data-id="ruler.after">after</a></li><li><a href="#Ruler.at" class="" title="Ruler.at (class method)" data-id="ruler.at">at</a></li><li><a href="#Ruler.before" class="" title="Ruler.before (class method)" data-id="ruler.before">before</a></li><li><a href="#Ruler.disable" class="" title="Ruler.disable (class method)" data-id="ruler.disable">disable</a></li><li><a href="#Ruler.enable" class="" title="Ruler.enable (class method)" data-id="ruler.enable">enable</a></li><li><a href="#Ruler.enableOnly" class="" title="Ruler.enableOnly (class method)" data-id="ruler.enableonly">enableOnly</a></li><li><a href="#Ruler.getRules" class="" title="Ruler.getRules (class method)" data-id="ruler.getrules">getRules</a></li><li><a href="#Ruler.push" class="" title="Ruler.push (class method)" data-id="ruler.push">push</a></li></ul></div></div></article><article class="docblock" id="Ruler.new" data-title="new Ruler (constructor)"><header><ul class="breadcrumbs"><li><a href="#home">Home</a></li><li><a href="#Ruler" class="" title="Ruler (class)" data-id="ruler">Ruler</a></li><li><a href="#Ruler.new" class="" title="new Ruler (constructor)" data-id="new ruler">new</a></li></ul><h2 title="constructor"><span class="name_prefix">Ruler.</span>new</h2><div class="source"><a href="https://github.com/markdown-it/markdown-it/blob/0fe7cc/lib/ruler.mjs#L22">View source</a></div></header><div class="section method"><div class="content"><ul class="signatures"><li><ul class="signature"><li class="signature-call">new Ruler()</li></ul></li></ul></div></div></article><article class="docblock" id="Ruler.after" data-title="Ruler.after (class method)"><header><ul class="breadcrumbs"><li><a href="#home">Home</a></li><li><a href="#Ruler" class="" title="Ruler (class)" data-id="ruler">Ruler</a></li><li><a href="#Ruler.after" class="" title="Ruler.after (class method)" data-id="ruler.after">after</a></li></ul><h2 title="class method"><span class="name_prefix">Ruler.</span>after</h2><div class="source"><a href="https://github.com/markdown-it/markdown-it/blob/0fe7cc/lib/ruler.mjs#L186">View source</a></div></header><div class="section method"><div class="content"><ul class="signatures"><li><ul class="signature"><li class="signature-call">Ruler.after(afterName, ruleName, fn[, options])</li></ul></li></ul><ul class="arguments"><li><ul class="argument"><li class="argument-name">afterName</li><li><ul class="argument-types"><li class="argument-type">String</li></ul></li><li class="argument-description"><p>new rule will be added after this one.</p>
|
||
|
</li></ul></li><li><ul class="argument"><li class="argument-name">ruleName</li><li><ul class="argument-types"><li class="argument-type">String</li></ul></li><li class="argument-description"><p>name of added rule.</p>
|
||
|
</li></ul></li><li><ul class="argument"><li class="argument-name">fn</li><li><ul class="argument-types"><li class="argument-type">Function</li></ul></li><li class="argument-description"><p>rule function.</p>
|
||
|
</li></ul></li><li><ul class="argument"><li class="argument-name">options</li><li><ul class="argument-types"><li class="argument-type">Object</li></ul></li><li class="argument-description"><p>rule options (not mandatory).</p>
|
||
|
</li></ul></li></ul><p>Add new rule to chain after one with given name. See also
|
||
|
<a href="#Ruler.before" class="link-short" title="Ruler.before (class method)" data-id="ruler.before">Ruler.before</a>, <a href="#Ruler.push" class="link-short" title="Ruler.push (class method)" data-id="ruler.push">Ruler.push</a>.</p>
|
||
|
<h5>Options:</h5>
|
||
|
<ul>
|
||
|
<li><strong>alt</strong> - array with names of "alternate" chains.</li>
|
||
|
</ul>
|
||
|
<h5>Example</h5>
|
||
|
<pre class="hljs language-javascript"><code><span class="hljs-keyword">var</span> md = <span class="hljs-built_in">require</span>(<span class="hljs-string">'markdown-it'</span>)();
|
||
|
|
||
|
md.<span class="hljs-property">inline</span>.<span class="hljs-property">ruler</span>.<span class="hljs-title function_">after</span>(<span class="hljs-string">'text'</span>, <span class="hljs-string">'my_rule'</span>, <span class="hljs-keyword">function</span> <span class="hljs-title function_">replace</span>(<span class="hljs-params">state</span>) {
|
||
|
<span class="hljs-comment">//...</span>
|
||
|
});
|
||
|
</code></pre>
|
||
|
</div></div></article><article class="docblock" id="Ruler.at" data-title="Ruler.at (class method)"><header><ul class="breadcrumbs"><li><a href="#home">Home</a></li><li><a href="#Ruler" class="" title="Ruler (class)" data-id="ruler">Ruler</a></li><li><a href="#Ruler.at" class="" title="Ruler.at (class method)" data-id="ruler.at">at</a></li></ul><h2 title="class method"><span class="name_prefix">Ruler.</span>at</h2><div class="source"><a href="https://github.com/markdown-it/markdown-it/blob/0fe7cc/lib/ruler.mjs#L111">View source</a></div></header><div class="section method"><div class="content"><ul class="signatures"><li><ul class="signature"><li class="signature-call">Ruler.at(name, fn[, options])</li></ul></li></ul><ul class="arguments"><li><ul class="argument"><li class="argument-name">name</li><li><ul class="argument-types"><li class="argument-type">String</li></ul></li><li class="argument-description"><p>rule name to replace.</p>
|
||
|
</li></ul></li><li><ul class="argument"><li class="argument-name">fn</li><li><ul class="argument-types"><li class="argument-type">Function</li></ul></li><li class="argument-description"><p>new rule function.</p>
|
||
|
</li></ul></li><li><ul class="argument"><li class="argument-name">options</li><li><ul class="argument-types"><li class="argument-type">Object</li></ul></li><li class="argument-description"><p>new rule options (not mandatory).</p>
|
||
|
</li></ul></li></ul><p>Replace rule by name with new function & options. Throws error if name not
|
||
|
found.</p>
|
||
|
<h5>Options:</h5>
|
||
|
<ul>
|
||
|
<li><strong>alt</strong> - array with names of "alternate" chains.</li>
|
||
|
</ul>
|
||
|
<h5>Example</h5>
|
||
|
<p>Replace existing typographer replacement rule with new one:</p>
|
||
|
<pre class="hljs language-javascript"><code><span class="hljs-keyword">var</span> md = <span class="hljs-built_in">require</span>(<span class="hljs-string">'markdown-it'</span>)();
|
||
|
|
||
|
md.<span class="hljs-property">core</span>.<span class="hljs-property">ruler</span>.<span class="hljs-title function_">at</span>(<span class="hljs-string">'replacements'</span>, <span class="hljs-keyword">function</span> <span class="hljs-title function_">replace</span>(<span class="hljs-params">state</span>) {
|
||
|
<span class="hljs-comment">//...</span>
|
||
|
});
|
||
|
</code></pre>
|
||
|
</div></div></article><article class="docblock" id="Ruler.before" data-title="Ruler.before (class method)"><header><ul class="breadcrumbs"><li><a href="#home">Home</a></li><li><a href="#Ruler" class="" title="Ruler (class)" data-id="ruler">Ruler</a></li><li><a href="#Ruler.before" class="" title="Ruler.before (class method)" data-id="ruler.before">before</a></li></ul><h2 title="class method"><span class="name_prefix">Ruler.</span>before</h2><div class="source"><a href="https://github.com/markdown-it/markdown-it/blob/0fe7cc/lib/ruler.mjs#L146">View source</a></div></header><div class="section method"><div class="content"><ul class="signatures"><li><ul class="signature"><li class="signature-call">Ruler.before(beforeName, ruleName, fn[, options])</li></ul></li></ul><ul class="arguments"><li><ul class="argument"><li class="argument-name">beforeName</li><li><ul class="argument-types"><li class="argument-type">String</li></ul></li><li class="argument-description"><p>new rule will be added before this one.</p>
|
||
|
</li></ul></li><li><ul class="argument"><li class="argument-name">ruleName</li><li><ul class="argument-types"><li class="argument-type">String</li></ul></li><li class="argument-description"><p>name of added rule.</p>
|
||
|
</li></ul></li><li><ul class="argument"><li class="argument-name">fn</li><li><ul class="argument-types"><li class="argument-type">Function</li></ul></li><li class="argument-description"><p>rule function.</p>
|
||
|
</li></ul></li><li><ul class="argument"><li class="argument-name">options</li><li><ul class="argument-types"><li class="argument-type">Object</li></ul></li><li class="argument-description"><p>rule options (not mandatory).</p>
|
||
|
</li></ul></li></ul><p>Add new rule to chain before one with given name. See also
|
||
|
<a href="#Ruler.after" class="link-short" title="Ruler.after (class method)" data-id="ruler.after">Ruler.after</a>, <a href="#Ruler.push" class="link-short" title="Ruler.push (class method)" data-id="ruler.push">Ruler.push</a>.</p>
|
||
|
<h5>Options:</h5>
|
||
|
<ul>
|
||
|
<li><strong>alt</strong> - array with names of "alternate" chains.</li>
|
||
|
</ul>
|
||
|
<h5>Example</h5>
|
||
|
<pre class="hljs language-javascript"><code><span class="hljs-keyword">var</span> md = <span class="hljs-built_in">require</span>(<span class="hljs-string">'markdown-it'</span>)();
|
||
|
|
||
|
md.<span class="hljs-property">block</span>.<span class="hljs-property">ruler</span>.<span class="hljs-title function_">before</span>(<span class="hljs-string">'paragraph'</span>, <span class="hljs-string">'my_rule'</span>, <span class="hljs-keyword">function</span> <span class="hljs-title function_">replace</span>(<span class="hljs-params">state</span>) {
|
||
|
<span class="hljs-comment">//...</span>
|
||
|
});
|
||
|
</code></pre>
|
||
|
</div></div></article><article class="docblock" id="Ruler.disable" data-title="Ruler.disable (class method)"><header><ul class="breadcrumbs"><li><a href="#home">Home</a></li><li><a href="#Ruler" class="" title="Ruler (class)" data-id="ruler">Ruler</a></li><li><a href="#Ruler.disable" class="" title="Ruler.disable (class method)" data-id="ruler.disable">disable</a></li></ul><h2 title="class method"><span class="name_prefix">Ruler.</span>disable</h2><div class="source"><a href="https://github.com/markdown-it/markdown-it/blob/0fe7cc/lib/ruler.mjs#L301">View source</a></div></header><div class="section method"><div class="content"><ul class="signatures"><li><ul class="signature"><li class="signature-call">Ruler.disable(list[, ignoreInvalid])</li><li><ul class="signature-values"><li>Array</li></ul></li></ul></li></ul><ul class="arguments"><li><ul class="argument"><li class="argument-name">list</li><li><ul class="argument-types"><li class="argument-type">String</li><li class="argument-type">Array</li></ul></li><li class="argument-description"><p>list of rule names to disable.</p>
|
||
|
</li></ul></li><li><ul class="argument"><li class="argument-name">ignoreInvalid</li><li><ul class="argument-types"><li class="argument-type">Boolean</li></ul></li><li class="argument-description"><p>set <code>true</code> to ignore errors when rule not found.</p>
|
||
|
</li></ul></li></ul><p>Disable rules with given names. If any rule name not found - throw Error.
|
||
|
Errors can be disabled by second param.</p>
|
||
|
<p>Returns list of found rule names (if no exception happened).</p>
|
||
|
<p>See also <a href="#Ruler.enable" class="link-short" title="Ruler.enable (class method)" data-id="ruler.enable">Ruler.enable</a>, <a href="#Ruler.enableOnly" class="link-short" title="Ruler.enableOnly (class method)" data-id="ruler.enableonly">Ruler.enableOnly</a>.</p>
|
||
|
</div></div></article><article class="docblock" id="Ruler.enable" data-title="Ruler.enable (class method)"><header><ul class="breadcrumbs"><li><a href="#home">Home</a></li><li><a href="#Ruler" class="" title="Ruler (class)" data-id="ruler">Ruler</a></li><li><a href="#Ruler.enable" class="" title="Ruler.enable (class method)" data-id="ruler.enable">enable</a></li></ul><h2 title="class method"><span class="name_prefix">Ruler.</span>enable</h2><div class="source"><a href="https://github.com/markdown-it/markdown-it/blob/0fe7cc/lib/ruler.mjs#L250">View source</a></div></header><div class="section method"><div class="content"><ul class="signatures"><li><ul class="signature"><li class="signature-call">Ruler.enable(list[, ignoreInvalid])</li><li><ul class="signature-values"><li>Array</li></ul></li></ul></li></ul><ul class="arguments"><li><ul class="argument"><li class="argument-name">list</li><li><ul class="argument-types"><li class="argument-type">String</li><li class="argument-type">Array</li></ul></li><li class="argument-description"><p>list of rule names to enable.</p>
|
||
|
</li></ul></li><li><ul class="argument"><li class="argument-name">ignoreInvalid</li><li><ul class="argument-types"><li class="argument-type">Boolean</li></ul></li><li class="argument-description"><p>set <code>true</code> to ignore errors when rule not found.</p>
|
||
|
</li></ul></li></ul><p>Enable rules with given names. If any rule name not found - throw Error.
|
||
|
Errors can be disabled by second param.</p>
|
||
|
<p>Returns list of found rule names (if no exception happened).</p>
|
||
|
<p>See also <a href="#Ruler.disable" class="link-short" title="Ruler.disable (class method)" data-id="ruler.disable">Ruler.disable</a>, <a href="#Ruler.enableOnly" class="link-short" title="Ruler.enableOnly (class method)" data-id="ruler.enableonly">Ruler.enableOnly</a>.</p>
|
||
|
</div></div></article><article class="docblock" id="Ruler.enableOnly" data-title="Ruler.enableOnly (class method)"><header><ul class="breadcrumbs"><li><a href="#home">Home</a></li><li><a href="#Ruler" class="" title="Ruler (class)" data-id="ruler">Ruler</a></li><li><a href="#Ruler.enableOnly" class="" title="Ruler.enableOnly (class method)" data-id="ruler.enableonly">enableOnly</a></li></ul><h2 title="class method"><span class="name_prefix">Ruler.</span>enableOnly</h2><div class="source"><a href="https://github.com/markdown-it/markdown-it/blob/0fe7cc/lib/ruler.mjs#L281">View source</a></div></header><div class="section method"><div class="content"><ul class="signatures"><li><ul class="signature"><li class="signature-call">Ruler.enableOnly(list[, ignoreInvalid])</li></ul></li></ul><ul class="arguments"><li><ul class="argument"><li class="argument-name">list</li><li><ul class="argument-types"><li class="argument-type">String</li><li class="argument-type">Array</li></ul></li><li class="argument-description"><p>list of rule names to enable (whitelist).</p>
|
||
|
</li></ul></li><li><ul class="argument"><li class="argument-name">ignoreInvalid</li><li><ul class="argument-types"><li class="argument-type">Boolean</li></ul></li><li class="argument-description"><p>set <code>true</code> to ignore errors when rule not found.</p>
|
||
|
</li></ul></li></ul><p>Enable rules with given names, and disable everything else. If any rule name
|
||
|
not found - throw Error. Errors can be disabled by second param.</p>
|
||
|
<p>See also <a href="#Ruler.disable" class="link-short" title="Ruler.disable (class method)" data-id="ruler.disable">Ruler.disable</a>, <a href="#Ruler.enable" class="link-short" title="Ruler.enable (class method)" data-id="ruler.enable">Ruler.enable</a>.</p>
|
||
|
</div></div></article><article class="docblock" id="Ruler.getRules" data-title="Ruler.getRules (class method)"><header><ul class="breadcrumbs"><li><a href="#home">Home</a></li><li><a href="#Ruler" class="" title="Ruler (class)" data-id="ruler">Ruler</a></li><li><a href="#Ruler.getRules" class="" title="Ruler.getRules (class method)" data-id="ruler.getrules">getRules</a></li></ul><h2 title="class method"><span class="name_prefix">Ruler.</span>getRules</h2><div class="source"><a href="https://github.com/markdown-it/markdown-it/blob/0fe7cc/lib/ruler.mjs#L331">View source</a></div></header><div class="section method"><div class="content"><ul class="signatures"><li><ul class="signature"><li class="signature-call">Ruler.getRules(chainName)</li><li><ul class="signature-values"><li>Array</li></ul></li></ul></li></ul><p>Return array of active functions (rules) for given chain name. It analyzes
|
||
|
rules configuration, compiles caches if not exists and returns result.</p>
|
||
|
<p>Default chain name is <code>''</code> (empty string). It can't be skipped. That's
|
||
|
done intentionally, to keep signature monomorphic for high speed.</p>
|
||
|
</div></div></article><article class="docblock" id="Ruler.push" data-title="Ruler.push (class method)"><header><ul class="breadcrumbs"><li><a href="#home">Home</a></li><li><a href="#Ruler" class="" title="Ruler (class)" data-id="ruler">Ruler</a></li><li><a href="#Ruler.push" class="" title="Ruler.push (class method)" data-id="ruler.push">push</a></li></ul><h2 title="class method"><span class="name_prefix">Ruler.</span>push</h2><div class="source"><a href="https://github.com/markdown-it/markdown-it/blob/0fe7cc/lib/ruler.mjs#L225">View source</a></div></header><div class="section method"><div class="content"><ul class="signatures"><li><ul class="signature"><li class="signature-call">Ruler.push(ruleName, fn[, options])</li></ul></li></ul><ul class="arguments"><li><ul class="argument"><li class="argument-name">ruleName</li><li><ul class="argument-types"><li class="argument-type">String</li></ul></li><li class="argument-description"><p>name of added rule.</p>
|
||
|
</li></ul></li><li><ul class="argument"><li class="argument-name">fn</li><li><ul class="argument-types"><li class="argument-type">Function</li></ul></li><li class="argument-description"><p>rule function.</p>
|
||
|
</li></ul></li><li><ul class="argument"><li class="argument-name">options</li><li><ul class="argument-types"><li class="argument-type">Object</li></ul></li><li class="argument-description"><p>rule options (not mandatory).</p>
|
||
|
</li></ul></li></ul><p>Push new rule to the end of chain. See also
|
||
|
<a href="#Ruler.before" class="link-short" title="Ruler.before (class method)" data-id="ruler.before">Ruler.before</a>, <a href="#Ruler.after" class="link-short" title="Ruler.after (class method)" data-id="ruler.after">Ruler.after</a>.</p>
|
||
|
<h5>Options:</h5>
|
||
|
<ul>
|
||
|
<li><strong>alt</strong> - array with names of "alternate" chains.</li>
|
||
|
</ul>
|
||
|
<h5>Example</h5>
|
||
|
<pre class="hljs language-javascript"><code><span class="hljs-keyword">var</span> md = <span class="hljs-built_in">require</span>(<span class="hljs-string">'markdown-it'</span>)();
|
||
|
|
||
|
md.<span class="hljs-property">core</span>.<span class="hljs-property">ruler</span>.<span class="hljs-title function_">push</span>(<span class="hljs-string">'my_rule'</span>, <span class="hljs-keyword">function</span> <span class="hljs-title function_">replace</span>(<span class="hljs-params">state</span>) {
|
||
|
<span class="hljs-comment">//...</span>
|
||
|
});
|
||
|
</code></pre>
|
||
|
</div></div></article><article class="docblock" id="Token" data-title="Token (class)"><header><ul class="breadcrumbs"><li><a href="#home">Home</a></li><li><a href="#Token" class="" title="Token (class)" data-id="token">Token</a></li></ul><h2 title="class">Token</h2><div class="source"><a href="https://github.com/markdown-it/markdown-it/blob/0fe7cc/lib/token.mjs#L6">View source</a></div></header><div class="section constructor"><h3>Constructor</h3><div class="content"></div><ul class="method-list"><li><a href="#Token.new" class="" title="new Token (constructor)" data-id="new token">new Token</a></li></ul></div><div class="section class_methods"><h3>Class methods</h3><div class="content"><ul class="method-list"><li><a href="#Token.attrGet" class="" title="Token.attrGet (class method)" data-id="token.attrget">attrGet</a></li><li><a href="#Token.attrIndex" class="" title="Token.attrIndex (class method)" data-id="token.attrindex">attrIndex</a></li><li><a href="#Token.attrJoin" class="" title="Token.attrJoin (class method)" data-id="token.attrjoin">attrJoin</a></li><li><a href="#Token.attrPush" class="" title="Token.attrPush (class method)" data-id="token.attrpush">attrPush</a></li><li><a href="#Token.attrSet" class="" title="Token.attrSet (class method)" data-id="token.attrset">attrSet</a></li></ul></div></div><div class="section instance_properties"><h3>Instance properties</h3><div class="content"><ul class="method-list"><li><a href="#Token.prototype.attrs" class="" title="Token#attrs (instance property)" data-id="token#attrs">attrs</a></li><li><a href="#Token.prototype.block" class="" title="Token#block (instance property)" data-id="token#block">block</a></li><li><a href="#Token.prototype.children" class="" title="Token#children (instance property)" data-id="token#children">children</a></li><li><a href="#Token.prototype.content" class="" title="Token#content (instance property)" data-id="token#content">content</a></li><li><a href="#Token.prototype.hidden" class="" title="Token#hidden (instance property)" data-id="token#hidden">hidden</a></li><li><a href="#Token.prototype.info" class="" title="Token#info (instance property)" data-id="token#info">info</a></li><li><a href="#Token.prototype.level" class="" title="Token#level (instance property)" data-id="token#level">level</a></li><li><a href="#Token.prototype.map" class="" title="Token#map (instance property)" data-id="token#map">map</a></li><li><a href="#Token.prototype.markup" class="" title="Token#markup (instance property)" data-id="token#markup">markup</a></li><li><a href="#Token.prototype.meta" class="" title="Token#meta (instance property)" data-id="token#meta">meta</a></li><li><a href="#Token.prototype.nesting" class="" title="Token#nesting (instance property)" data-id="token#nesting">nesting</a></li><li><a href="#Token.prototype.tag" class="" title="Token#tag (instance property)" data-id="token#tag">tag</a></li><li><a href="#Token.prototype.type" class="" title="Token#type (instance property)" data-id="token#type">type</a></li></ul></div></div></article><article class="docblock" id="Token.new" data-title="new Token (constructor)"><header><ul class="breadcrumbs"><li><a href="#home">Home</a></li><li><a href="#Token" class="" title="Token (class)" data-id="token">Token</a></li><li><a href="#Token.new" class="" title="new Token (constructor)" data-id="new token">new</a></li></ul><h2 title="constructor"><span class="name_prefix">Token.</span>new</h2><div class="source"><a href="https://github.com/markdown-it/markdown-it/blob/0fe7cc/lib/token.mjs#L12">View source</a></div></header><div class="section method"><div class="content"><ul class="signatures"><li><ul class="signature"><li class="signature-call">new Token(type, tag, nesting)</li></ul></li></ul><p>Create new token and fill passed properties.</p>
|
||
|
</div></div></article><article class="docblock" id="Token.attrGet" data-title="Token.attrGet (class method)"><header><ul class="breadcrumbs"><li><a href="#home">Home</a></li><li><a href="#Token" class="" title="Token (class)" data-id="token">Token</a></li><li><a href="#Token.attrGet" class="" title="Token.attrGet (class method)" data-id="token.attrget">attrGet</a></li></ul><h2 title="class method"><span class="name_prefix">Token.</span>attrGet</h2><div class="source"><a href="https://github.com/markdown-it/markdown-it/blob/0fe7cc/lib/token.mjs#L166">View source</a></div></header><div class="section method"><div class="content"><ul class="signatures"><li><ul class="signature"><li class="signature-call">Token.attrGet(name)</li></ul></li></ul><p>Get the value of attribute <code>name</code>, or null if it does not exist.</p>
|
||
|
</div></div></article><article class="docblock" id="Token.attrIndex" data-title="Token.attrIndex (class method)"><header><ul class="breadcrumbs"><li><a href="#home">Home</a></li><li><a href="#Token" class="" title="Token (class)" data-id="token">Token</a></li><li><a href="#Token.attrIndex" class="" title="Token.attrIndex (class method)" data-id="token.attrindex">attrIndex</a></li></ul><h2 title="class method"><span class="name_prefix">Token.</span>attrIndex</h2><div class="source"><a href="https://github.com/markdown-it/markdown-it/blob/0fe7cc/lib/token.mjs#L121">View source</a></div></header><div class="section method"><div class="content"><ul class="signatures"><li><ul class="signature"><li class="signature-call">Token.attrIndex(name)</li><li><ul class="signature-values"><li>Number</li></ul></li></ul></li></ul><p>Search attribute index by name.</p>
|
||
|
</div></div></article><article class="docblock" id="Token.attrJoin" data-title="Token.attrJoin (class method)"><header><ul class="breadcrumbs"><li><a href="#home">Home</a></li><li><a href="#Token" class="" title="Token (class)" data-id="token">Token</a></li><li><a href="#Token.attrJoin" class="" title="Token.attrJoin (class method)" data-id="token.attrjoin">attrJoin</a></li></ul><h2 title="class method"><span class="name_prefix">Token.</span>attrJoin</h2><div class="source"><a href="https://github.com/markdown-it/markdown-it/blob/0fe7cc/lib/token.mjs#L181">View source</a></div></header><div class="section method"><div class="content"><ul class="signatures"><li><ul class="signature"><li class="signature-call">Token.attrJoin(name, value)</li></ul></li></ul><p>Join value to existing attribute via space. Or create new attribute if not
|
||
|
exists. Useful to operate with token classes.</p>
|
||
|
</div></div></article><article class="docblock" id="Token.attrPush" data-title="Token.attrPush (class method)"><header><ul class="breadcrumbs"><li><a href="#home">Home</a></li><li><a href="#Token" class="" title="Token (class)" data-id="token">Token</a></li><li><a href="#Token.attrPush" class="" title="Token.attrPush (class method)" data-id="token.attrpush">attrPush</a></li></ul><h2 title="class method"><span class="name_prefix">Token.</span>attrPush</h2><div class="source"><a href="https://github.com/markdown-it/markdown-it/blob/0fe7cc/lib/token.mjs#L137">View source</a></div></header><div class="section method"><div class="content"><ul class="signatures"><li><ul class="signature"><li class="signature-call">Token.attrPush(attrData)</li></ul></li></ul><p>Add <code>[ name, value ]</code> attribute to list. Init attrs if necessary</p>
|
||
|
</div></div></article><article class="docblock" id="Token.attrSet" data-title="Token.attrSet (class method)"><header><ul class="breadcrumbs"><li><a href="#home">Home</a></li><li><a href="#Token" class="" title="Token (class)" data-id="token">Token</a></li><li><a href="#Token.attrSet" class="" title="Token.attrSet (class method)" data-id="token.attrset">attrSet</a></li></ul><h2 title="class method"><span class="name_prefix">Token.</span>attrSet</h2><div class="source"><a href="https://github.com/markdown-it/markdown-it/blob/0fe7cc/lib/token.mjs#L150">View source</a></div></header><div class="section method"><div class="content"><ul class="signatures"><li><ul class="signature"><li class="signature-call">Token.attrSet(name, value)</li></ul></li></ul><p>Set <code>name</code> attribute to <code>value</code>. Override old value if exists.</p>
|
||
|
</div></div></article><article class="docblock" id="Token.prototype.attrs" data-title="Token#attrs (instance property)"><header><ul class="breadcrumbs"><li><a href="#home">Home</a></li><li><a href="#Token" class="" title="Token (class)" data-id="token">Token</a></li><li><a href="#Token.prototype.attrs" class="" title="Token#attrs (instance property)" data-id="token#attrs">attrs</a></li></ul><h2 title="instance property"><span class="name_prefix">Token#</span>attrs</h2><div class="source"><a href="https://github.com/markdown-it/markdown-it/blob/0fe7cc/lib/token.mjs#L32">View source</a></div></header><div class="section method"><div class="content"><ul class="signatures"><li><ul class="signature"><li class="signature-call">Token#attrs</li><li><ul class="signature-values"><li>Array</li></ul></li></ul></li></ul><p>Html attributes. Format: <code>[ [ name1, value1 ], [ name2, value2 ] ]</code></p>
|
||
|
</div></div></article><article class="docblock" id="Token.prototype.block" data-title="Token#block (instance property)"><header><ul class="breadcrumbs"><li><a href="#home">Home</a></li><li><a href="#Token" class="" title="Token (class)" data-id="token">Token</a></li><li><a href="#Token.prototype.block" class="" title="Token#block (instance property)" data-id="token#block">block</a></li></ul><h2 title="instance property"><span class="name_prefix">Token#</span>block</h2><div class="source"><a href="https://github.com/markdown-it/markdown-it/blob/0fe7cc/lib/token.mjs#L105">View source</a></div></header><div class="section method"><div class="content"><ul class="signatures"><li><ul class="signature"><li class="signature-call">Token#block</li><li><ul class="signature-values"><li>Boolean</li></ul></li></ul></li></ul><p>True for block-level tokens, false for inline tokens.
|
||
|
Used in renderer to calculate line breaks</p>
|
||
|
</div></div></article><article class="docblock" id="Token.prototype.children" data-title="Token#children (instance property)"><header><ul class="breadcrumbs"><li><a href="#home">Home</a></li><li><a href="#Token" class="" title="Token (class)" data-id="token">Token</a></li><li><a href="#Token.prototype.children" class="" title="Token#children (instance property)" data-id="token#children">children</a></li></ul><h2 title="instance property"><span class="name_prefix">Token#</span>children</h2><div class="source"><a href="https://github.com/markdown-it/markdown-it/blob/0fe7cc/lib/token.mjs#L64">View source</a></div></header><div class="section method"><div class="content"><ul class="signatures"><li><ul class="signature"><li class="signature-call">Token#children</li><li><ul class="signature-values"><li>Array</li></ul></li></ul></li></ul><p>An array of child nodes (inline and img tokens)</p>
|
||
|
</div></div></article><article class="docblock" id="Token.prototype.content" data-title="Token#content (instance property)"><header><ul class="breadcrumbs"><li><a href="#home">Home</a></li><li><a href="#Token" class="" title="Token (class)" data-id="token">Token</a></li><li><a href="#Token.prototype.content" class="" title="Token#content (instance property)" data-id="token#content">content</a></li></ul><h2 title="instance property"><span class="name_prefix">Token#</span>content</h2><div class="source"><a href="https://github.com/markdown-it/markdown-it/blob/0fe7cc/lib/token.mjs#L72">View source</a></div></header><div class="section method"><div class="content"><ul class="signatures"><li><ul class="signature"><li class="signature-call">Token#content</li><li><ul class="signature-values"><li>String</li></ul></li></ul></li></ul><p>In a case of self-closing tag (code, html, fence, etc.),
|
||
|
it has contents of this tag.</p>
|
||
|
</div></div></article><article class="docblock" id="Token.prototype.hidden" data-title="Token#hidden (instance property)"><header><ul class="breadcrumbs"><li><a href="#home">Home</a></li><li><a href="#Token" class="" title="Token (class)" data-id="token">Token</a></li><li><a href="#Token.prototype.hidden" class="" title="Token#hidden (instance property)" data-id="token#hidden">hidden</a></li></ul><h2 title="instance property"><span class="name_prefix">Token#</span>hidden</h2><div class="source"><a href="https://github.com/markdown-it/markdown-it/blob/0fe7cc/lib/token.mjs#L113">View source</a></div></header><div class="section method"><div class="content"><ul class="signatures"><li><ul class="signature"><li class="signature-call">Token#hidden</li><li><ul class="signature-values"><li>Boolean</li></ul></li></ul></li></ul><p>If it's true, ignore this element when rendering. Used for tight lists
|
||
|
to hide paragraphs.</p>
|
||
|
</div></div></article><article class="docblock" id="Token.prototype.info" data-title="Token#info (instance property)"><header><ul class="breadcrumbs"><li><a href="#home">Home</a></li><li><a href="#Token" class="" title="Token (class)" data-id="token">Token</a></li><li><a href="#Token.prototype.info" class="" title="Token#info (instance property)" data-id="token#info">info</a></li></ul><h2 title="instance property"><span class="name_prefix">Token#</span>info</h2><div class="source"><a href="https://github.com/markdown-it/markdown-it/blob/0fe7cc/lib/token.mjs#L90">View source</a></div></header><div class="section method"><div class="content"><ul class="signatures"><li><ul class="signature"><li class="signature-call">Token#info</li><li><ul class="signature-values"><li>String</li></ul></li></ul></li></ul><p>Additional information:</p>
|
||
|
<ul>
|
||
|
<li>Info string for "fence" tokens</li>
|
||
|
<li>The value "auto" for autolink "link_open" and "link_close" tokens</li>
|
||
|
<li>The string value of the item marker for ordered-list "list_item_open" tokens</li>
|
||
|
</ul>
|
||
|
</div></div></article><article class="docblock" id="Token.prototype.level" data-title="Token#level (instance property)"><header><ul class="breadcrumbs"><li><a href="#home">Home</a></li><li><a href="#Token" class="" title="Token (class)" data-id="token">Token</a></li><li><a href="#Token.prototype.level" class="" title="Token#level (instance property)" data-id="token#level">level</a></li></ul><h2 title="instance property"><span class="name_prefix">Token#</span>level</h2><div class="source"><a href="https://github.com/markdown-it/markdown-it/blob/0fe7cc/lib/token.mjs#L57">View source</a></div></header><div class="section method"><div class="content"><ul class="signatures"><li><ul class="signature"><li class="signature-call">Token#level</li><li><ul class="signature-values"><li>Number</li></ul></li></ul></li></ul><p>nesting level, the same as <code>state.level</code></p>
|
||
|
</div></div></article><article class="docblock" id="Token.prototype.map" data-title="Token#map (instance property)"><header><ul class="breadcrumbs"><li><a href="#home">Home</a></li><li><a href="#Token" class="" title="Token (class)" data-id="token">Token</a></li><li><a href="#Token.prototype.map" class="" title="Token#map (instance property)" data-id="token#map">map</a></li></ul><h2 title="instance property"><span class="name_prefix">Token#</span>map</h2><div class="source"><a href="https://github.com/markdown-it/markdown-it/blob/0fe7cc/lib/token.mjs#L39">View source</a></div></header><div class="section method"><div class="content"><ul class="signatures"><li><ul class="signature"><li class="signature-call">Token#map</li><li><ul class="signature-values"><li>Array</li></ul></li></ul></li></ul><p>Source map info. Format: <code>[ line_begin, line_end ]</code></p>
|
||
|
</div></div></article><article class="docblock" id="Token.prototype.markup" data-title="Token#markup (instance property)"><header><ul class="breadcrumbs"><li><a href="#home">Home</a></li><li><a href="#Token" class="" title="Token (class)" data-id="token">Token</a></li><li><a href="#Token.prototype.markup" class="" title="Token#markup (instance property)" data-id="token#markup">markup</a></li></ul><h2 title="instance property"><span class="name_prefix">Token#</span>markup</h2><div class="source"><a href="https://github.com/markdown-it/markdown-it/blob/0fe7cc/lib/token.mjs#L79">View source</a></div></header><div class="section method"><div class="content"><ul class="signatures"><li><ul class="signature"><li class="signature-call">Token#markup</li><li><ul class="signature-values"><li>String</li></ul></li></ul></li></ul><p>'*' or '_' for emphasis, fence string for fence, etc.</p>
|
||
|
</div></div></article><article class="docblock" id="Token.prototype.meta" data-title="Token#meta (instance property)"><header><ul class="breadcrumbs"><li><a href="#home">Home</a></li><li><a href="#Token" class="" title="Token (class)" data-id="token">Token</a></li><li><a href="#Token.prototype.meta" class="" title="Token#meta (instance property)" data-id="token#meta">meta</a></li></ul><h2 title="instance property"><span class="name_prefix">Token#</span>meta</h2><div class="source"><a href="https://github.com/markdown-it/markdown-it/blob/0fe7cc/lib/token.mjs#L97">View source</a></div></header><div class="section method"><div class="content"><ul class="signatures"><li><ul class="signature"><li class="signature-call">Token#meta</li><li><ul class="signature-values"><li>Object</li></ul></li></ul></li></ul><p>A place for plugins to store an arbitrary data</p>
|
||
|
</div></div></article><article class="docblock" id="Token.prototype.nesting" data-title="Token#nesting (instance property)"><header><ul class="breadcrumbs"><li><a href="#home">Home</a></li><li><a href="#Token" class="" title="Token (class)" data-id="token">Token</a></li><li><a href="#Token.prototype.nesting" class="" title="Token#nesting (instance property)" data-id="token#nesting">nesting</a></li></ul><h2 title="instance property"><span class="name_prefix">Token#</span>nesting</h2><div class="source"><a href="https://github.com/markdown-it/markdown-it/blob/0fe7cc/lib/token.mjs#L50">View source</a></div></header><div class="section method"><div class="content"><ul class="signatures"><li><ul class="signature"><li class="signature-call">Token#nesting</li><li><ul class="signature-values"><li>Number</li></ul></li></ul></li></ul><p>Level change (number in {-1, 0, 1} set), where:</p>
|
||
|
<ul>
|
||
|
<li><code>1</code> means the tag is opening</li>
|
||
|
<li><code>0</code> means the tag is self-closing</li>
|
||
|
<li><code>-1</code> means the tag is closing</li>
|
||
|
</ul>
|
||
|
</div></div></article><article class="docblock" id="Token.prototype.tag" data-title="Token#tag (instance property)"><header><ul class="breadcrumbs"><li><a href="#home">Home</a></li><li><a href="#Token" class="" title="Token (class)" data-id="token">Token</a></li><li><a href="#Token.prototype.tag" class="" title="Token#tag (instance property)" data-id="token#tag">tag</a></li></ul><h2 title="instance property"><span class="name_prefix">Token#</span>tag</h2><div class="source"><a href="https://github.com/markdown-it/markdown-it/blob/0fe7cc/lib/token.mjs#L25">View source</a></div></header><div class="section method"><div class="content"><ul class="signatures"><li><ul class="signature"><li class="signature-call">Token#tag</li><li><ul class="signature-values"><li>String</li></ul></li></ul></li></ul><p>html tag name, e.g. "p"</p>
|
||
|
</div></div></article><article class="docblock" id="Token.prototype.type" data-title="Token#type (instance property)"><header><ul class="breadcrumbs"><li><a href="#home">Home</a></li><li><a href="#Token" class="" title="Token (class)" data-id="token">Token</a></li><li><a href="#Token.prototype.type" class="" title="Token#type (instance property)" data-id="token#type">type</a></li></ul><h2 title="instance property"><span class="name_prefix">Token#</span>type</h2><div class="source"><a href="https://github.com/markdown-it/markdown-it/blob/0fe7cc/lib/token.mjs#L18">View source</a></div></header><div class="section method"><div class="content"><ul class="signatures"><li><ul class="signature"><li class="signature-call">Token#type</li><li><ul class="signature-values"><li>String</li></ul></li></ul></li></ul><p>Type of the token (string, e.g. "paragraph_open")</p>
|
||
|
</div></div></article><footer class="footer"><p>Last updated on Mon, 18 Mar 2024 23:17:43 GMT. Generated by <a href="http://github.com/nodeca/ndoc">ndoc</a></p></footer></div></body></html>
|