前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >打造一款 刷Java 知识的小程序(二)

打造一款 刷Java 知识的小程序(二)

作者头像
悟空聊架构
发布2020-03-12 10:49:52
4320
发布2020-03-12 10:49:52
举报

一、第二版做了什么?

  • 第一版小程序只具有初级展示功能,知识点都是hardcode在代码里面的。
  • 这一次进行了大升级,知识点从后端(小程序云开发)获取
  • 知识点都是用Markdown语言写的,支持将Markdown内容无缝转换成小程序页面。

二、C端与后端的交互逻辑

mark

2.1、功能跳转

  • 首页点击Java基础图标进入到Java基础知识列表页面
  • 列表页点击“查看”按钮进入详情页面

2.2、准备工作

1.云开发存储上传一个markdown文件

2.云开发数据库插入两条记录

2.2、代码实现

  1. 调用 自己编写的云函数 getJavaQuestionList 获取列表;
  2. 调用 自己编写的云函数 getJavaQuestionDetail 获取详情的 Markdown文件路径;
  3. 调用 系统自带的云函数 downloadFile 下载 Markdown文件保存为临时文件;
  4. 调用 小程序自带的 saveFileSync 将临时文件保存到本地;
  5. 调用 小程序自带的 readFileSync 将本地文件读入缓存(注意:开发者工具上不需要保存到本地也可以正常读取);
  6. 使用 towxml 开源组件将缓存中markdown内容转成小程序可以识别的元素
  7. 给 图片元素添加预览事件

三、我与Markdown大战一天一晚

痛点:Markdown转小程序页面很难受,小程序页面并不能识别Markdown标记。

方案一、用Typora工具将 Markdown文件复制为html内容直接粘贴到表字段里面

mark

遇到的问题,发现复制的HTML代码都不包含样式,而用小程序富文本组件后,在WXSS文件定义样式对富文本里面的标签元素是不生效的。于是只能自己加样式,那就用正则匹配标签来加style吧。写着写着发现好多style要加。比如h1,h2,image。最坑的是Markdown转为html是code标签,小程序不识别code标签,所以将code标签转为div标签,然后还得处理换行,而且针对代码需要有不同的高亮显示,这太麻烦了。但基本上已经不影响阅读了。

mark

方案二、将Markdown文件复制为markdown格式内容直接粘贴到表字段里面

找到一个开源组件可以将markdown 标记转为小程序元素,叫做wemark。

于是就把markdown 内容复制到数据库中,但发现存到数据库的是没有换行的,所以读取之后需要做换行处理,这里就又用到正则表达式了。处理完了也能正常显示了,但图片不能放大看,这个就比较难受了。

方案三、将Markdown文件存到某个地方,比如COS,阿里云,七牛云,自己搭建的服务器

这里是将文件上传到小程序云开发的存储里面,而且小程序提供了对应的下载云存储文件的SDK,非常方便。

然后使用towxml开源组件将markdown转为小程序元素,和wemark相比优势如下:

1.支持自定义towxml组件哪些功能开放,比如转换markdown的图表、数学公式等

2.支持自定义towxml 支持哪些code格式高亮

3.支持绑定小程序元素事件(这个功能太棒了)

大战一天一晚完美解决Markdown转小程序的问题

4. 后续计划

貌似直接用小程序云开发就够用了,但云开发的访问次数,存储空间有限制。另外直接操作云开发控制台不方便,做个后台操作起来更方便、更安全。之前搭建的一个服务器因到期被回收了,又得重新搭一套了。另外会先在本地把后端服务和Portal先跑起来。

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2020-03-10 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 二、C端与后端的交互逻辑
    • 2.1、功能跳转
      • 2.2、准备工作
        • 1.云开发存储上传一个markdown文件
        • 2.云开发数据库插入两条记录
      • 2.2、代码实现
      • 三、我与Markdown大战一天一晚
        • 方案一、用Typora工具将 Markdown文件复制为html内容直接粘贴到表字段里面
          • 方案二、将Markdown文件复制为markdown格式内容直接粘贴到表字段里面
            • 方案三、将Markdown文件存到某个地方,比如COS,阿里云,七牛云,自己搭建的服务器
            • 4. 后续计划
            相关产品与服务
            云开发 CloudBase
            云开发(Tencent CloudBase,TCB)是腾讯云提供的云原生一体化开发环境和工具平台,为200万+企业和开发者提供高可用、自动弹性扩缩的后端云服务,可用于云端一体化开发多种端应用(小程序、公众号、Web 应用等),避免了应用开发过程中繁琐的服务器搭建及运维,开发者可以专注于业务逻辑的实现,开发门槛更低,效率更高。
            领券
            问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档