为 Editor.md 编辑器插件增加预览和发布按钮
前言
一直在使用 Editor.md 插件作为博客的编辑器,用着挺好,但是在全屏下编辑时,每次想预览或者保存又必须切换到非全屏状态下才可以点击按钮,用着不舒服,所以花了一点时间在工具栏上增加了预览、保存、发布三个按钮,在此记录一下修改的过程。
开发
根据 Editor.md 设置中的 "编辑器设置 > 编辑器静态资源地址" 找到静态资源文件,我的博客是放在了 wordpress 根目录下的 assets 文件夹下,修改文件 /assets/Config/editormd.js,增加内容如下:
var toolBar;
switch (textareaID) {
case 'wp-content-editor-container' :
toolBar = fullToolBar;
break;
case 'comment' :
toolBar = simpleToolBar;
break;
case 'wp-replycontent-editor-container' :
toolBar = miniToolBar;
break;
}
+var postSaveText = $("#publish").val();
+var toolbarHandlers = {};
+if($("body").hasClass("wp-admin") && ($("body").hasClass("post-type-post") || $("body").hasClass("post-type-page")){
+ // 预览更改
+ toolBar.push('||', 'postPreview');
+ // 保存草稿
+ if($("#save-post").size() == 1){
+ toolBar.push('postSaveDraft');
+ }
+ // 发布/更新
+ toolBar.push('postSave');
+
+ toolbarHandlers = {
+ /**
+ * @param {Object} cm CodeMirror对象
+ * @param {Object} icon 图标按钮jQuery元素对象
+ * @param {Object} cursor CodeMirror的光标对象,可获取光标所在行和位置
+ * @param {String} selection 编辑器选中的文本
+ */
+ postPreview: function(cm, icon, cursor, selection){
+ $("#post-preview").click();
+ },
+ postSaveDraft: function(cm, icon, cursor, selection){
+ $("#save-post").click();
+ },
+ postSave: function(cm, icon, cursor, selection){
+ if($("#publish").attr("name") == "save"){
+ $("#publish").click();
+ }else if(confirm("您确定要" + postSaveText + "文章吗?")){
+ $("#publish").click();
+ }
+ },
+ };
+}
var wpEditormd = editormd({
id: textareaID,
path: editor.editormdUrl + '/assets/Editormd/lib/',
width: '100%', //编辑器宽度
height: textareaID === 'wp-content-editor-container' ? 640 : 320, //编辑器高度
syncScrolling: editor.syncScrolling !== 'off', //即是否开启同步滚动预览
// ........
// 其他代码
// .......
onload: function () {
//加载完成执行
if ( textareaID === 'comment' ) {
//修改评论表单name
$('textarea.editormd-markdown-textarea').attr('name', 'comment');
}
if ( textareaID === 'wp-replycontent-editor-container' ) {
$('.reply').click(function () {
setTimeout(function () {
$('.edit-comments-php .CodeMirror.cm-s-default.CodeMirror-wrap').css('margin-top',$('.editormd-toolbar').height());
},100);
})
}
if (getWidth() === 1600) {
// 1600分辨率删除编辑器编辑空白外边距
var codeMirror = $('.editormd .CodeMirror.CodeMirror-wrap');
var codeMirrorMarginTop = codeMirror.css('margin-top');
codeMirror.css('margin-top',parseInt(codeMirrorMarginTop) - 32 + "px");
}
},
+ toolbarIconsClass: {
+ // 指定一个FontAawsome的图标类
+ postPreview: "fa-chrome",
+ postSaveDraft: "fa-floppy-o",
+ postSave: "fa-paper-plane",
+ },
+ lang: {
+ toolbar: {
+ postPreview: "预览更改",
+ postSaveDraft: "保存草稿",
+ postSave: postSaveText,
+ }
+ },
+ // 自定义工具栏按钮的事件处理
+ toolbarHandlers: toolbarHandlers
});
压缩
将编写好后的代码压缩,然后替换掉同级目录下的 editormd.min.js,就大功告成了!
效果
部署好后,工具栏右上角就会多出三个按钮,然后就可以愉快的在全屏下写文章了~

参考资料
原文链接:https://acme.top/blog-feature-editor-md-add-btns
为 Editor.md 编辑器插件增加预览和发布按钮的更多相关文章
- 自己动手开发更好用的markdown编辑器-04(实时预览)
这里文章都是从个人的github博客直接复制过来的,排版可能有点乱. 原始地址 http://benq.im/2015/04/25/hexomd-04/ 程序打包 文章目录 1. 打开新窗口 ...
- 使用pdfjs插件在线预览PDF文件
前言 本文介绍在html中使用 pdfjs插件在线预览PDF文件的方法. 实现步骤 下载 pdfjs 并引入项目中 到PDFJS官网 http://mozilla.github.io/pdf.js/g ...
- ubuntu自带的gedit编辑器添加Markdown预览插件
gedit安装Markdown Preview Ubuntu自带的gedit编辑器也是有很强大的功能的,且支持插件的安装.对于喜欢用Markdown的我来说,这当然是很好的了,gedit本身 就支持M ...
- markown编辑器截图粘贴预览,并将图片传至七牛云
最近在做一个项目,需要实现类似QQ截图后,就是能够在富文本编辑器中粘贴截图并预览. 先看一下效果: 分析一下实现步骤: QQ截图后在编辑器中粘贴,肯定会有一个粘贴事件,即 paste 事件 在事件回调 ...
- PHP专业开发IDE——Zend Studio 10.5预览版发布
Zend Studio是新一代的PHP IDE,高效的开发和维护PHP代码是它的核心.Zend公司目前已发布了Zend Studio 10.5预览版,预览版中提高了快速响应能力和时时误差检查.因此使用 ...
- sql server 2014预览版发布
MSDN发布sql server2014预览版,如下图: SQL Server 2014新特性: 微软SQL Server部门主管Eron Kelly介绍,通过将交易处理放到内存中进行,新的SQL S ...
- vs2015下载及预览与发布
VS2015 RC发布下载,通用Windows平台必备神器! 几个月前微软发布了Visual Studio 2015的技术预览版本,之后又先后发布了6个更新版本.如今,微软已在其官方页面中公布了最新开 ...
- Window 7 平台的IE11浏览器预览版发布
继之前Windows 8.1 带来了IE11浏览器之后,今天Window 7 以及Windows Server 2008 R2平台的IE11浏览器预览版也已经发布. 当然这还只是一个开发者预览版,可能 ...
- UEditor百度富文本编辑器--preview在线预览时头部被挡住的解决方案
问题截图: 正常情况应该是如下显示: 解决方案: 1.打开ueditor/dialogs/preview/preview.html 2.找到body节点下面这一句 document.getElemen ...
随机推荐
- Qt单元测试浅析
Qt单元测试框架,使用于基于Qt的应用程序和库,先从一个简单的demo工程说起吧. 我们可以通过QtCreator来创建一个简单的Qt单元测试工程,夏天到了,这个demo工程的名字就叫Summer好了 ...
- 网络基础与FTP准备
一网络基础 1.端口: 端口是为了将同一台电脑上的不同程序进行隔离 (IP是在找电脑,端口是在找电脑上的程序) 实例: MySQL是一个软件,帮助我们在硬盘上进行操作,默认端口是3306 Redis是 ...
- python常用删除库的方法
本文记于初学py的时候,两年后补发. python常用库的安装方法一般有几种,比如: 1.编译过的exe包,直接无脑下一步就可以了. 2.pip install 库名,快速安装.自动匹配最新版本. 3 ...
- 一步一步教你用IntelliJ IDEA 搭建SSM框架(3)——实现用户登录功能
上面两篇博客已经详细的介绍了在IntelliJ IDEA 搭建SSM框架的整个过程,下面我们就要在搭建好的环境里实现我们想要的功能了.本文完成用户的登录功能,主要包括:用户注册,登录,编辑,退出,注销 ...
- Free MP3 CD Ripper_缓冲区溢出远程代码执行_CVE-2019-9766漏洞复现
Free MP3 CD Ripper_缓冲区溢出远程代码执行_CVE-2019-9766漏洞复现 一.漏洞描述 Free MP3 CD Ripper是一款音频格式转换器.Free MP3 CD Rip ...
- Storm 学习之路(一)—— Storm和流处理简介
一.Storm 1.1 简介 Storm 是一个开源的分布式实时计算框架,可以以简单.可靠的方式进行大数据流的处理.通常用于实时分析,在线机器学习.持续计算.分布式RPC.ETL等场景.Storm具有 ...
- spring cloud 系列第8篇 —— config+bus 分布式配置中心与配置热刷新 (F版本)
源码Gitub地址:https://github.com/heibaiying/spring-samples-for-all 一.config 简介 spring cloud config 分为服务端 ...
- SSM(三)Mybatis动态SQL
1.查询语句,where: <resultMap id="xxx" type="xx..Student" autoMapping="false& ...
- redis在asp.net 中的应用
1.redis介绍 Nosql数据库作为关系型数据库的补充,在互联网公司已经得到广泛的运用.redis便是其中的代表之一,redis是一种(key,value)基于内存的数据库,并支持多种数据结构,如 ...
- Rstudio调用plot()函数时,出现错误的处理方法
按照书上的例子敲出代码后,发现Rstudio无法识别C盘user文件夹下的中文用户名.如下图所示: 按照网上的做法,尝试修改计算机user下的用户名,没修改成功. 另一种做法是在plot()函数前面加 ...