个人随笔
目录
微信小程序解析HTML和MARKDOWN
2020-04-30 23:15:41

Towxml

Towxml 是一个可将HTML、markdown转换为WXML(WeiXin Markup Language)的渲染库。

由于微信小程序不能直接渲染HTML,因此富文本编辑器生成的HTML内容无法直接在小程序中展示。

可能是出于安全因素考虑,即使WXML文本在小程序中也是以字符串方式进行渲染。

所以……

然后……

于是,Towxml 就因此降临了。

Towxml 下载

https://github.com/sbfkcel/towxml

  • 特色
  • 支持代码语法高亮
  • 使用简单
  • 多主题动态支持
  • 极致的中文排版优化
  • 快速上手

1. 克隆TOWXML到小程序根目录

  1. git clone https://github.com/sbfkcel/towxml.git
2. 在小程序app.js中引入库
  1. //app.js
  2. const Towxml = require('/towxml/main'); //引入towxml库
  3. App({
  4. onLaunch: function () {
  5. },
  6. towxml:new Towxml() //创建towxml对象,供小程序页面使用
  7. })

3. 在小程序页面文件中引入模版

  1. <!--pages/index.wxml-->
  2. <!--引入towxml模版入口文件,并使用模版-->
  3. <import src="/towxml/entry.wxml"/>
  4. <template is="entry" data="{{...article}}"/>

4. 在小程序对应的js中请求数据

  1. //pages/index.js
  2. const app = getApp();
  3. Page({
  4. data: {
  5. //article将用来存储towxml数据
  6. article:{}
  7. },
  8. onLoad: function () {
  9. const _ts = this;
  10. //请求markdown文件,并转换为内容
  11. wx.request({
  12. url: 'http://xxx/doc.md',
  13. header: {
  14. 'content-type': 'application/x-www-form-urlencoded'
  15. },
  16. success: (res) => {
  17. //将markdown内容转换为towxml数据
  18. let data = app.towxml.toJson(res.data,'markdown');
  19. //设置文档显示主题,默认'light'
  20. data.theme = 'dark';
  21. //设置数据
  22. _ts.setData({
  23. article: data
  24. });
  25. }
  26. });
  27. }
  28. })

5. 引入对应的WXSS

  1. /**pages/index.wxss**/
  2. /**基础风格样式**/
  3. @import '/towxml/style/main.wxss';
  4. /**如果页面有动态主题切换,则需要将使用到的样式全部引入**/
  5. /**主题配色(浅色样式)**/
  6. @import '/towxml/style/theme/light.wxss';
  7. /**主题配色(深色样式)**/
  8. @import '/towxml/style/theme/dark.wxss';

OK,大功告成~~

如果为了追求极致的体验,建议将markdown、html转换为towxml数据的过程放在服务器上,在小程序中直接请求数据即可。

3. 接口使用

  1. const Towxml = require('towxml');
  2. const towxml = new Towxml();
  3. //Markdown转WXML
  4. let wxml = towxml.md2wxml('# Article title');
  5. //html转WXML
  6. let wxml = towxml.html2wxml('<h1>Article title</h1>');
  7. //Markdown转towxml数据
  8. let data = towxml.toJson('# Article title','markdown');
  9. //htm转towxml数据
  10. let data = towxml.toJson('# Article title');

转自:https://www.jianshu.com/p/c4e819e110cb

 820

啊!这个可能是世界上最丑的留言输入框功能~


当然,也是最丑的留言列表

有疑问发邮件到 : suibibk@qq.com 侵权立删
Copyright : 个人随笔   备案号 : 粤ICP备18099399号-2