Greasy Fork is available in English.
掘金Markdown编辑器增强脚本:从本地导入Markdown文件,并对文档做一些处理:居中图片、居中图片标注的文字、解决==无法高亮的问题
当前为
// ==UserScript==
// @name 掘金Markdown增强器
// @namespace http://tampermonkey.net/
// @version 0.1
// @description 掘金Markdown编辑器增强脚本:从本地导入Markdown文件,并对文档做一些处理:居中图片、居中图片标注的文字、解决==无法高亮的问题
// @author LiarCoder
// @match https://juejin.cn/editor/*
// @icon 
// @grant none
// ==/UserScript==
(function () {
'use strict';
// 该函数用于创建一个<eleName k="attrs[k]">text</eleName>样式的页面元素
function createEle(eleName, text, attrs) {
let ele = document.createElement(eleName);
// innerText 也就是 <p>text会被添加到这里</p>
ele.innerText = text;
// attrs 的类型是一个 map
for (let k in attrs) {
// 遍历 attrs, 给节点 ele 添加我们想要的属性
ele.setAttribute(k, attrs[k]);
}
// 返回节点
return ele;
}
const inputTag = createEle('input', '', {
id: 'juejin-enhancer-import-md-file',
accept: '.md',
type: 'file',
style: 'display: none'
});
const importLabel = createEle('label', '', {
for: 'juejin-enhancer-import-md-file',
title: '导入Markdown文件',
style: `display: inline-block;
width: 14px;
height: 14px;
cursor: pointer;
margin: 5px 10px;
background-image: url(https://i.loli.net/2021/08/30/SH5kMUjyAFqDn2V.png);
background-size: 14px 14px;
background-color: white !important;
border-radius: 2px;`
});
// 设置定时器是为了防止文档中还未加载出相关的元素
setTimeout(() => {
let btnGroup = document.querySelector('#juejin-web-editor > div.edit-draft > div > div > div > div.bytemd-toolbar > div.bytemd-toolbar-right');
console.log(btnGroup);
btnGroup.insertBefore(inputTag, btnGroup.firstChild);
btnGroup.insertBefore(importLabel, btnGroup.firstChild);
// 本来是想直接把处理好的文本内容放到编辑器中对应的节点的,虽然确实可以把文本塞进去,但是似乎没法达到预期的效果
// const inputCase = document.querySelector('#juejin-web-editor > div.edit-draft > div > div > div > div.bytemd-body > div.bytemd-editor > div > div.CodeMirror-scroll > div.CodeMirror-sizer > div > div > div > div.CodeMirror-code > pre');
if (window.FileList && window.File && window.FileReader) {
document.getElementById('juejin-enhancer-import-md-file').addEventListener('change', event => {
const file = event.target.files[0];
const reader = new FileReader();
reader.addEventListener('load', event => {
let content = event.target.result;
// console.log(typeof event.target.result);
// 替换高亮处,将 == 包裹的文本改为用 <mark></mark> 标签包裹
// let reg = new RegExp('==[^==]*==','g'); // 这个正则表达式也是可以实现功能的,但下面的更通用
let highLightReplace = content.match(/==(?:(?!(==)).)*==/g);
// console.log(highLightReplace, `共有${highLightReplace.length}处高亮`);
for (let i = 0; i < highLightReplace.length; i++) {
highLightReplace[i] = '<mark>' + highLightReplace[i].substr(highLightReplace[i].indexOf('==') + 2, highLightReplace[i].lastIndexOf('==') - 2) + '</mark>';
}
for (let i = 0; i < highLightReplace.length; i++) {
content = content.replace(/==(?:(?!(==)).)*==/, highLightReplace[i]);
}
// 替换图片链接格式,将 ![]() 包裹的图片改为用 <div align="center"><img src=""></div> 标签包裹
let imgReplace = content.match(/!\[.*\]\(.*\)/g);
for (let i = 0; i < imgReplace.length; i++) {
let imgLink = imgReplace[i].slice(imgReplace[i].indexOf('(') + 1, imgReplace[i].lastIndexOf(')'));
imgReplace[i] = `<div align="center"><img src="${imgLink}"></div>`;
}
for (let i = 0; i < imgReplace.length; i++) {
content = content.replace(/!\[.*\]\(.*\)/, imgReplace[i]);
}
// 替换居中格式,将 <center></center> 包裹的内容改为用 <div align="center"></div> 标签包裹
let centerReplace = content.match(/<center>.*<\/center>/g);
for (let i = 0; i < centerReplace.length; i++) {
let centerContent = centerReplace[i].slice(centerReplace[i].indexOf('>') + 1, centerReplace[i].lastIndexOf('<'));
centerReplace[i] = `<div align="center">${centerContent}</div>`;
}
for (let i = 0; i < centerReplace.length; i++) {
content = content.replace(/<center>.*<\/center>/, centerReplace[i]);
}
// inputCase.innerText = content;
// 因为直接往上面的 inputCase 里放文本内容的话,掘金的Markdown编辑器没法儿按预期效果解析,所以直接把处理好的内容放到剪切板里
navigator.clipboard.writeText(content);
});
// reader.readAsDataURL(file);
reader.readAsText(file);
// 2021年8月30日01:05:44成功实现读取文件并修改的操作。
});
}
}, 2000);
})();