和微信公众号编辑器战斗的日子

640?wx_fmt=jpeg

作者:灵魂画师牧码

本文提到的 Markdown Nice 体验地址:https://mdnice.com

公元 2019 年,微信公众号排版能力孱弱,始终为运营者所诟病,秀米、135 编辑器等工具割据一方。

但无论是微信原生工具,还是其他编辑器,都让创作者不得不将有限的创作经历分散到排版设计上。

Markdown 解决排版的灵丹妙药,应运而生。

一、引子

1.1 Markdown 是什么?

Markdown 是一种排版语法,拥有极简的输入方式和极低的学习成本。

富含了标题、引用、加粗、链接、图片、代码段、公式等一切在文字创作中需要的排版格式。

拥有它,让人专注于内容本身,而不被格式所打扰。

640?wx_fmt=gif

1.2 怎么和微信公众号结合?

这么优秀的排版语法,可是微信公众号也不支持呀。

别急!Markdown Nice 来帮你解决问题!

1.3 Markdown Nice 是什么?

一款开源 Markdown 编辑器,写完后即排版成功,复制即可粘贴到微信公众号。

So what?只有这点么?

当然不是!Nice宝宝你还有什么特性呀?

640?wx_fmt=png
  • 支持图床、脚注、代码、公式

  • 支持 8 种排版主题和 7 种代码主题

  • 支持自定义样式,可提交主题供人瞻仰

  • 除了公众号外,还支持知乎、掘金、博客园和CSDN等平台

  • 我颜值高呀

640?wx_fmt=png
完整界面

这么多优秀的特性摆在你面前,还在等什么?

地址:https://mdnice.com

快让你的微信排版 Nice 起来!

二、正文

没想到你还在看

咳咳、、、

不要小看Nice宝宝我,为了能够使用 Markdown 进行公众号排版,我可是和微信公众号编辑器做了半年的斗争,才赢得了现在的战果!

640?wx_fmt=gif
激烈斗争

想听听我是如何战斗的?下面且听我娓娓道来!

2.1 战斗序章

微信公众号编辑器源于百度 FEX 前端团队的开源的 ueditor[1] 项目,这可是宝宝我扒取了网页代码发现的,如图所示:

640?wx_fmt=png
浏览器检查元素

因为 ueditor 是富文本编辑器,所以我即将面临的是 markdown->富文本 的转换战役,在开源界或者软件界这种转换战役有了相当多的优秀实现。比如:

  • Web端:editor.md[2]mavonEditor[3]

  • PC端:typora[4]MWeb[5]

但是上述工具都存在一个问题,没有很好地将 CSS 样式融入富文本中,进而适配微信编辑器,以至于国内其他各大平台的富文本编辑器。

那么有没有尝试弥补这一问题的工具呢?其实是有的:

  • Web端:md2all[6]wechat-format[7]

  • 浏览器插件:markdown-here[8]

但是上述工具也各自有不完美的地方,于是Nice宝宝我发现了这个契机,把自己生产了出来,解决一切不完美!

Markdown Nice 是一个开源项目,由很多开源技术合体而成,其中主要包括:

  • React[9]:facebook 开源的 js 视图层框架

  • markdown-it[10]:markdown 转换富文本解析器

  • juice[11]:将 CSS 类选择器转换为行内样式的工具

  • codemirror[12]:网页代码编辑器

  • ant-design[13]:React UI组件库

  • mobx[14]:状态管理库

  • highlight.js[15]:代码高亮库

  • MathJax-node[16]:公式转图片库

  • axios、ali-oss、qiniu-js等

注:下文会提到上述某些开源库,开源库具体作用请参考此处。

在拥有上述技术傍身之后,我向微信编辑器宣战,打响了战斗第一枪!

640?wx_fmt=jpeg

2.2 战斗第一枪:代码主题

微信公众号在2018年以前,是完全不支持代码块的,目前的支持也很单一,并且存在代码字体较大的问题。

说来很气,微信公众号编辑器的开发者,就木有想过代码块对程序员群体是多么重要么??

640?wx_fmt=jpeg

为此我找来了highlight.js代码高亮神器,帮助解决代码主题单一的问题。

经过一定的筛选后,最终选定了 atom-one-dark、atom-one-light、monikai、GitHub、vs2015、xcode 和微信代码主题共 7 个代码样式供大家选择。

其中微信代码主题由于其不属于highlight.js的归属范畴,故而其结构需要从微信公众号编辑器源码中获取,下面两张图展示了如何获取:

640?wx_fmt=png
获取iframe的id
640?wx_fmt=png
微信代码块源码

highlight.jsmarkdown-it 解析器是关联使用的,故而工具中存在 2 个 markdown 解析器,分别用于解析微信代码主题和其他代码主题,源码参考[17]

除了上述问题外,很多技术类公众号代码中会存在:一行代码过长导致的多行显示问题

该问题使用以下 CSS 代码即可解决:

pre code {	
  display: -webkit-box !important	
}

对比效果如图所示:

640?wx_fmt=jpeg
代码换行和不换行对比

从此以后使用 Markdown Nice 的同志们代码更美观啦!

2.3 战斗第二枪:图片上传

一篇好的文章怎么可以没有图片?

(某些技术人员说:我的就没有)

640?wx_fmt=gif

图片管理是每一个成熟编辑器都会遇到的问题。

Nice 宝宝最开始使用 SM.MS[18] 图床,该图床由一位大佬在运维,非常感谢!

使用该图床虽然能够上传图片,但是粘贴到微信编辑器时,失败率极高(想踩死微信编辑器),如图所示:

640?wx_fmt=png
图片上传失败

真是喜闻乐见hē hē hē hē呀!

为了解决上述问题,Markdown Nice 先后支持了自定义阿里云和七牛云图床,通过购买阿里云和七牛云的服务使用自建图床。

但是!让使用者自己配置,尽管有配置文档,但是整个配置过程复杂无比,简直惨绝人寰!

640?wx_fmt=jpeg
吐血身亡

于是,Nice 宝宝又使用自己的账号,自建图床,设定保存时间为一天,提供临时排版使用的 mdnice 图床。至此,工具中的图片上传支持情况如下:

图床费用有效期失败率
mdnice免费1天
SM.MS免费长期
阿里云参考[19]自定义
七牛云10G免费自定义
640?wx_fmt=png
四种图床

这场图床的战役中,最大的难度在于需要阅读阿里云 OSS 和七牛云 KODO 的文档,并且使用其开源出来的工具包 ali-oss 和 qiniu-js 。

这其中又涉及到了 FormData、file对象、base64 和 blob 之间的神奇转换,源码参考[20]

总之,这场战斗打的不亦乐乎。

2.4 战斗第三枪:数学公式

微信公众号排版中,数学公式是一个噩梦!

因为微信编辑器做了以下三件事情:

  • 不支持公式编辑

  • 不支持 html 和 css 生成的公式,因为字体无法导入

  • 不支持 svg,放入后提示失败

这三件事情简直像魔鬼的步伐,把公式需求者放在光滑的地板上摩擦、摩擦....

640?wx_fmt=jpeg

目前唯一可行的方案就是将公式转换成图片,再将图片直接贴到公众号里,Nice宝宝觉得自己这个想法简直是完美!

但是,怎么做呢......

640?wx_fmt=jpeg

忽然灵机一动,想到了朋友曾经推荐的一个转换公式网站 codecogs[21],这个网站能够做到将任意公式转换成png图片并给出可访问链接。

640?wx_fmt=png
codecogs

但是由于图片稳定性,无法直接使用该链接,会存在和第二场战役一样,图片粘贴失败的情况,让人苦不堪言。

  • 这个问题该怎么解决呢?如果能够自建公式转png图片服务就好了。

  • 有没有这样的开源库?有!MathJax-node 就可以!

于是Nice宝宝自建后台服务,封装 RESTful 接口供前端调用,实现了公式转图片的功能!经过测试,完全可以使用,粘贴后再根据排版情况调整图片大小即可。

其中对于大量公式的转换,前端合理使用了异步请求,并非一个个转换而是并行执行,性能上达到了10个公式也能2秒转换完毕的效果,完全可用于公式排版。

640?wx_fmt=gif
转公式

2.5 战斗第四枪:微信外链转脚注

众所周知(不知道也得知道),微信不支持外链,除了域名为https://mp.weixin.qq.com/的合法链接外,其他的链接出现后都会被自动删除。

而添加外链的唯一官方方式就是在阅读全文处,当然,直接将链接本身放到文中或者制作二维码图片也是可以的选择。

而 Nice 宝宝则提供了将微信外链转为脚注的方式解决该问题,是不是很优雅呢?

640?wx_fmt=jpeg

其中链接和脚注的使用区别如下:

链接:[文字](链接 "文字")	
脚注:[文字](脚注解释 "脚注名字")

这里又涉及到了一个常见的问题,就是很多公众号作者的文章中,原来在其他平台发布时都是链接,而到这里排版时需要进行挨个修改,实在是让人头大。

640?wx_fmt=jpeg

于是Nice宝宝我又做了一个小改进,就是在粘贴文章的时候会自动监测是否存在外链,并提示作者是否一键转成脚注,这样就不必手工修改了,赞不赞!

640?wx_fmt=gif
自动转脚注

2.6 战役总结

和微信公众号编辑器对抗,是个极其有意思的过程。除了上述提到的问题之外,还有很多的细节点需要注意,在此就不一一讨论了,感兴趣欢迎阅读源码。

Markdown Nice 的战斗之旅还远远没有结束,官网制作、浏览器插件、本地工具和排版纠正等功能蓄势待发。

三、谈点和战斗无关的

3.1 设计理念

大多数人而言,内容重于排版,排版重于设计。

内容是吸引读者的核心,所以最重要。

而排版与设计之间的比较,作为一个曾经的微信美术编辑,随着排版经验的增多,发现文章的效果并不在于额外的花边、点缀。

整齐、舒服、简单是硬道理!

3.2 内容、排版与设计

设计 = 排版 + 创意


因为:大多数人不会获取创意,或认为创意成本过高。

所以:大多数人不做设计,富文本设计不适合单纯的内容编辑者。


虽然:大多数人也不会排版,或认为排版成本过高。

但是:Markdown Nice 将用户从排版中释放出来,只关注内容本身。

3.3 关于开源

开源是个既简单又困难的过程:

  • 说简单是因为:笔记、书单、工具、平台所有有价值的东西都可以在 GitHub 中输出,做起来很简单

  • 说困难是因为:努力做到对别人有价值,始终坚持输出,做起来很困难

正如上面描述的那样,做开源其实是在做一款产品,有可能是技术产品(比如 redis、ant design),也有可能是业务产品(比如 Markdown Nice),只有做好了才可能对别人产生价值。

做产品的过程曲折而漫长,对照 Markdown Nice 开发过程,可以看到以下的步骤:

  1. 要有一个 idea,并且验证其可行性和必要性,去和同类产品比较,做到心中有数

  2. 抓住痛点,掌握核心价值,站在用户角度思考,多听反馈意见

  3. 螺旋上升,不断迭代,产出精品

  4. 最最重要一点,做产品不只要写代码,还要宣传呀!!酒香也怕巷子深!!

参与开源,一路走来,甚是不易,望君珍惜。

最后,感谢每一位开源参与者,欢迎更多人参与到开源中来,还有好多代码等着有人来写呢!

参考资料

[1]ueditor: http://ueditor.baidu.com
[2]editor.md: https://github.com/pandao/editor.md
[3]mavonEditor: https://github.com/hinesboy/mavonEditor

[4]typora: https://typora.io/
[5]MWeb: https://zh.mweb.im/
[6]md2all: http://md.aclickall.com/

[7]wechat-format: https://github.com/lyricat/wechat-format
[8]markdown-here: https://markdown-here.com/
[9]React: https://github.com/facebook/react

[10]markdown-it: https://github.com/markdown-it/markdown-itjuice: https://github.com/Automattic/juiceDoctests: https://nose.readthedocs.io/en/latest/plugins/deprecated.html

[12]codemirror: https://github.com/codemirror/codemirror
[13]ant-design: https://github.com/ant-design/ant-design
[14]mobx: https://github.com/mobxjs/mobx

[15]highlight.js: https://github.com/highlightjs/highlight.js
[16]MathJax-node: https://github.com/mathjax/MathJax-node

[17]源码参考: https://github.com/zhning12/markdown-nice/blob/master/src/utils/helper.js#L55-L133
[18]SM.MS: https://sm.ms/

[19]参考: https://cn.aliyun.com/product/oss
[20]源码参考: https://github.com/zhning12/markdown-nice/blob/master/src/component/Dialog/ImageDialog.js

[21]codecogs: https://private.codecogs.com/latex/eqneditor.php

640?wx_fmt=png

关注公众号加入交流群,一起讨论有趣的技术话题

『讲解开源项目系列』——让对开源项目感兴趣的人不再畏惧、让开源项目的发起者不再孤单。跟着我们的文章,你会发现编程的乐趣、使用和发现参与开源项目如此简单。欢迎联系我(微信:xueweihan,备注:讲解)加入我们,让更多人爱上开源、贡献开源~

“阅读原文”获取更多信息、“在看”让本文被更多人看到、“赞赏”支持我们。

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值