代码拉取完成,页面将自动刷新
同步操作将从 笔心/mdeditor 强制同步,此操作会覆盖自 Fork 仓库以来所做的任何修改,且无法恢复!!!
确定后同步将在后台操作,完成时将刷新页面,请耐心等待。
var mdeditor = function (options) {
return new mdeditor.prototype.init(options);
};
mdeditor.prototype.init = function (options) {
var me = this;
if (options && options.id) {
var defaults = {
id: '',
placeholder: '',
name: ''
};
me.copy(defaults, options);
var wrap = this.getDom(options.id);
var html = '<textarea id="mdeditor" class="mdeditor" name="{name}" placeholder="{placeholder}"></textarea><div id="mdeditor-html" class="mdeditor-html"></div>';
html = me.formatString(html, defaults);
wrap.innerHTML = html;
var editor = this.getDom('mdeditor');
var editorHtml = this.getDom('mdeditor-html');
editor.addEventListener('input', function () {
var txt = this.value;
me.markdownToHtml(txt);
});
me.editor = editor;
me.editorHtml = editorHtml;
}
return me;
};
mdeditor.prototype.init.prototype = mdeditor.prototype;
mdeditor.prototype.regApi = {
code: /^\`{3}.*$/,
ul: /^[\.\-\*]\s?.+$/,
ol: /^\d+\.\s?.+$/,
toc: /^\s*\[TOC\]\s*$/,
img: /\!\[.*?\]\(.*?\)/g,
title: /^#{1,6}.+$/,
blockquote: /^\>\s+.+$/
};
// 格式化字符串
mdeditor.prototype.formatString = function (format, data) {
return format.replace(/{\w+}/g, function ($1) {
var key = $1.substr(1, $1.length - 2);
return data[key];
});
};
// js浅拷贝
mdeditor.prototype.copy = function (source, dest) {
for (var name in dest) {
source[name] = dest[name];
}
return source;
};
// 获取dom元素
mdeditor.prototype.getDom = function (_id) {
return document.getElementById(_id);
};
// 获取markdown内容
mdeditor.prototype.getMarkdown = function () {
if (this.editor) {
return this.editor.value;
} else {
return null;
}
};
// 设置markdown内容
mdeditor.prototype.setMarkdown = function (markdown) {
if (this.editor) {
this.editor.value = markdown;
}
return this.markdownToHtml(markdown);
};
// 获取markdown转义后的HTML代码
mdeditor.prototype.getHTML = function () {
if (this.editorHtml) {
return this.editorHtml.innerHTML;
} else {
return '';
}
};
// markdown语法文本转义为html
mdeditor.prototype.markdownToHtml = function (md) {
var me = this;
var flag = '';
var arr = [];
// 逐行分析
var html = md.replace(/^.+$/mg, function (txt) {
var preHtml = '';
if (me.regApi.toc.test(txt)) {
me.toc = [];
return '';
}
if (flag == 'ul' && !me.regApi.ul.test(txt)) {
arr.push('</ul>');
preHtml = arr.join('');
flag = '';
arr = [];
}
if (flag == 'ol' && !me.regApi.ol.test(txt)) {
arr.push('</ol>');
preHtml = arr.join('');
flag = '';
arr = [];
}
// 遇到代码起始标记,标记为代码
if (flag == '' && flag != 'code' && me.regApi.code.test(txt)) {
flag = 'code';
me.codeType = txt.replace(/[`\s]/g, '');
arr.push(preHtml);
return '';
}
if (flag == '' && flag != 'ul' && me.regApi.ul.test(txt)) {
flag = 'ul';
arr.push(preHtml);
arr.push('<ul class="mdeditor-ul">');
}
if (flag == '' && flag != 'ol' && me.regApi.ol.test(txt)) {
flag = 'ol';
arr.push(preHtml);
arr.push('<ol class="mdeditor-ol">');
}
switch (flag) {
case 'code':
// 处理代码
if (flag == 'code' && /^\`{3}.*$/.test(txt)) {
flag = '';
preHtml = arr.shift();
var codeHtml = me.handleCode(arr);
arr = [];
return preHtml + '<pre class="mdeditor-code">' + codeHtml + '</pre>';
} else {
arr.push(me.replaceHtmlTag(txt));
return '';
}
case 'ul':
arr.push(me.handleUnorderedList(txt));
return '';
case 'ol':
arr.push(me.handleOrderList(txt));
return '';
case '':
// 图片处理
if (me.regApi.img.test(txt)) {
return preHtml + me.handleImg(txt);
}
return preHtml + me.handleText(txt);
}
});
if (me.toc) {
me.toc.unshift('<div class="mdeditor-toc" id="mdeditor-toc">');
me.toc.push('</div>');
html = me.toc.join('') + html;
me.toc = null;
} else {
var $toc = me.getDom('mdeditor-toc');
if ($toc) {
$toc.remove();
}
}
if (flag == 'ul') {
arr.push('</ul>');
html += arr.join('');
} else if (flag == 'ol') {
arr.push('</ol>');
html += arr.join('');
}
if (this.editorHtml) {
this.editorHtml.innerHTML = html;
}
return html;
};
// 格式化
mdeditor.prototype.handleText = function (txt) {
var me = this;
/* 超链接处理 */
txt = this.handleLink(txt);
/* 行内代码处理 */
txt = this.handleInlineCode(txt);
if (me.regApi.title.test(txt)) {
var titleMatches = txt.match(/#{1,6}(?=.+)/);
var hno = titleMatches[0].length;
var htxt = txt.substr(hno);
if (me.toc) {
me.handleTOC(hno, htxt, htxt);
}
return '<h' + hno + ' id="' + htxt + '" >' + htxt + '</h' + hno + '>';
} else {
return '<p>' + txt + '</p>';
}
return '';
};
// 格式化目录语法
mdeditor.prototype.handleTOC = function (hno, anchor, txt) {
var me = this;
me.toc.push('<a class="mdeditor-toc-' + hno + '" href="#' + anchor + '">' + txt + '</a>');
};
mdeditor.prototype.handleImg = function (txt) {
var alt = txt.substring(txt.indexOf('[') + 1, txt.indexOf(']'));
var src = txt.substring(txt.indexOf('(') + 1, txt.length - 1);
return '<img alt="' + alt + '" src="' + src + '">';
};
// 格式化无序列表
mdeditor.prototype.handleUnorderedList = function (txt) {
var me = this;
txt = me.handleLink(txt);
txt = me.handleInlineCode(txt);
txt = txt.replace(/^[\.\*\-]\s*/, '');
return '<li>' + txt + '</li>';
};
// 格式化有序列表
mdeditor.prototype.handleOrderList = function (txt) {
var me = this;
txt = me.handleLink(txt);
txt = me.handleInlineCode(txt);
txt = txt.replace(/^\d+\.\s*/, '');
return '<li>' + txt + '</li>';
};
// 格式化链接
mdeditor.prototype.handleLink = function (txt) {
var targetBlankReg = /.*(?=\,\s*_blank)/;
return txt.replace(/\[.*?\]\(.*?\)/g, function (txt) {
var target = '_self';
var targetBlankMatch = txt.match(targetBlankReg);
if (targetBlankMatch) {
target = '_blank';
txt = targetBlankMatch[0] + ')';
}
var linkText = txt.substring(1, txt.indexOf(']'));
var linkUrl = txt.substring(txt.indexOf('(') + 1, txt.length - 1);
return '<a href="' + linkUrl + '" target="' + target + '">' + linkText + '</a>';
});
};
// 格式化代码段
mdeditor.prototype.handleCode = function (arr) {
var me = this;
var codeHtml = [];
codeHtml.push('<ol>');
for (var i = 0, j = arr.length; i < j; i++) {
var codeLine = arr[i];
if (i % 2 == 0) {
codeHtml.push('<li class="md-code-line-even">');
} else {
codeHtml.push('<li class="md-code-line-odd">');
}
codeHtml.push('<code>');
codeHtml.push(me.handleCodeType(codeLine));
codeHtml.push('</code>');
codeHtml.push('</li>');
}
codeHtml.push('</ol>');
return codeHtml.join('');
};
mdeditor.prototype.handleCodeType = function (txt) {
var me = this;
switch (me.codeType.toLocaleLowerCase()) {
case 'css':
return txt.replace(/([a-zA-Z-]+:)([^;]+)(;?)/, '<span class="css-property-name">$1</span><span class="css-property-value">$2</span><span class="css-semicolon">$3</span>');
default:
return txt;
}
};
// 格式化行内代码
mdeditor.prototype.handleInlineCode = function (txt) {
var me = this;
return txt.replace(/\`.+?\`/g, function (txt) {
var inlineCode = txt.substring(1, txt.length - 1);
inlineCode = me.replaceHtmlTag(inlineCode);
return '<span class="md-inline-code">' + inlineCode + '</span>';
});
};
// 替换html标签
mdeditor.prototype.replaceHtmlTag = function (txt) {
return txt.replace(/\</g, '<').replace(/\>/, '>')
};
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。