// ==UserScript== // @name 掘金Markdown增强器 // @namespace http://tampermonkey.net/ // @version 0.1 // @description 掘金Markdown编辑器增强脚本:居中图片,居中图片标注的文字;高亮用==包裹的文本 // @author LiarCoder // @match https://juejin.cn/editor/* // @icon  // @grant none // @downloadURL none // ==/UserScript== (function () { 'use strict'; // 该函数用于创建一个text样式的页面元素 function createEle(eleName, text, attrs) { let ele = document.createElement(eleName); // innerText 也就是

text会被添加到这里

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); // 替换高亮处,将 == 包裹的文本改为用 标签包裹 // 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] = '' + highLightReplace[i].substr(highLightReplace[i].indexOf('==') + 2, highLightReplace[i].lastIndexOf('==') - 2) + ''; } for (let i = 0; i < highLightReplace.length; i++) { content = content.replace(/==(?:(?!(==)).)*==/, highLightReplace[i]); } // 替换图片链接格式,将 ![]() 包裹的图片改为用
标签包裹 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] = `
`; } for (let i = 0; i < imgReplace.length; i++) { content = content.replace(/!\[.*\]\(.*\)/, imgReplace[i]); } // 替换居中格式,将
包裹的内容改为用
标签包裹 let centerReplace = content.match(/
.*<\/center>/g); for (let i = 0; i < centerReplace.length; i++) { let centerContent = centerReplace[i].slice(centerReplace[i].indexOf('>') + 1, centerReplace[i].lastIndexOf('<')); centerReplace[i] = `
${centerContent}
`; } for (let i = 0; i < centerReplace.length; i++) { content = content.replace(/
.*<\/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); })();