一位微信小程序萌新的学渣笔记(五)towxml的小白教程——简单高效的将md文档转化为wxml网页


前言

将md文档的内容转化为wxml网页 减少wxml的书写 使用的是towxml工具

实在是太太太小白了 小白到用了两天的时间去实现这个功能呜呜呜 又白又菜 简称小白菜 写个博客记录一下

本篇博客将讲述如何简单的将md文档储存在云开发上再转化为wxml页面

towxml的介绍

Towxml 是一个可将HTMLMarkdown转为微信小程序WXML(WeiXin Markup Language)的渲染库。

用于解决在微信小程序中MarkdownHTML不能直接渲染的问题。

特色

  • 可控制的音频播放器(可自行调节样式,解决原生audio在部分iPhone上不能自动播放的情况)
  • 支持代码语法高亮
  • 支持emoji表情😉
  • 支持上标、下标、下划线、删除线、表格、视频、图片(几乎所有html元素)……
  • 支持typographer字符替换
  • 多主题动态支持
  • 极致的中文排版优化
  • Markdown TodoList
  • 支持事件绑定(这样允许自行扩展功能哟,例如:点击页面中的某个元素,更新当前页面内容等…)
  • 前后端支持

音频播放器播放状态设定为每5秒更新一次,否则内容过多会导致性能下降

towxml文件分享

在这里插入图片描述
百度云分享地址

链接:https://pan.baidu.com/s/1Kg9I0y-AvK7WwytSts-WsA
提取码:pphl

快速上手

1. 将TOWXML文件夹复制到小程序的根目录下
注意:主要是与app.js和pages同一个层级
在这里插入图片描述
2. 在小程序app.js中引入库

//app.js
const Towxml = require('/towxml/main');
App({
  onLaunch: function ()
  {
  },
  //创建一个towxml对象,供其它页面调用
  towxml : new Towxml(),

  // //声明Markdown文件目录路径
  docDir: 'https://xxxx.tcb.qcloud.la/',
  //xxx中的内容是云开发库名
  //声明一个数据请求方法
  getText: (url, callback) => {
    wx.request({
      url: url,
      header: {
        'content-type': 'application/octet-stream'
      },
      success: (res) => {
        if (typeof callback === 'function') {
          callback(res);
        };
      }
    });
  },
})

👆
在这里插入图片描述
框住的地方被我马赛克了!!小伙伴不要太懒了 要自己动手去看看哦

3. 创建你需要转化md文档网页
例如创建一个demo的文件夹
里面有4个基础配置文件index
在这里插入图片描述

4. 在云开发存储md文档

举例子 proposal.md文档内容

第七届提案征集大赛(学术)

本大赛作为学校“青研杯”调研比赛的一个专项竞赛,将由提案申报、校区初赛、校区复赛与总决赛四个环节,推选出2019-2020年度校园”十大优秀提案“。

活动时间

2020年3月-2020年5月

活动地点

华南师范大学全校

面向对象

华南师范大学全日制本科生与研究生

选题范围

教务管理类,如教学质量、学分设置等。
生活服务类,如垃圾分类、日常缴费等。
校园发展类,如设施建设、校园文化等。
科研学术类,如培养机制、特色课程等。

在这里插入图片描述
我在云开发创建了一个university文件夹
上传了一个proposal.md到university文件夹

这里可以随意!主要是看自己的需求

5. index.wxml中的代码

<!--miniprogram/pages/demo/index.wxml-->
<!--使用towxml-->
<view class="text">
    <import src="/towxml/entry.wxml" />
    <template is="entry" data="{{...article}}" />
   </view>
<!--使用towxml end-->

6. index.js中的内容

// miniprogram/pages/demo/index.js
const app = getApp();
Page({
  data: {
    article: {},
  },
  /**********************   文件转换部分js start  ***********************/
  onLoad: function (options) {
    let that = this

    wx.showToast({title: '加载中', icon: 'loading', duration: 10000});
   
    app.getText(app.docDir + 'university/proposal.md', (res) => {
      if (res.data) {
        //将markdown内容转换为towxml数据
        let articleData = app.towxml.toJson(res.data, 'markdown');
        
        //设置文章数据,并清除页面loading
        //设置文章数据
        that.setData({
          article: articleData,
        });
        wx.hideToast();//清除页面loading
      };
    });
  }
})

7. index.json中的内容

{
  "usingComponents": {}
}

8. index.wxss中的内容

/* miniprogram/pages/demo/index.wxss */
/**主题配色**/
@import '/towxml/style/main.wxss';

/**如果页面有动态主题切换,则需要将使用到的样式全部引入**/

/**主题配色(浅色样式)**/
@import '/towxml/style/theme/light.wxss';

/**主题配色(深色样式)**/
@import '/towxml/style/theme/dark.wxss';

9. 编译成功
在这里插入图片描述

基于该基础的修改与运用

md图片的上传

如果在md文档上放了一张图片,需要将图片上传到云开发上才可以显示

例如我在university文件夹中建立一个img文件夹,其中储存了一张photo.jpg的图片

则图片路径为

[testphoto](https://xxxx.tcb.qcloud.la/university/img/photo.jpg  "phototest")

样式的修改

具体样式运用要看调试器
在这里插入图片描述
修改towxml里towxml\style\main.wxss中的相对应的样式,达到自己想要的效果

在这里插入图片描述

更多的towxml的运用

towxml官方文档如下

Towxml

Towxml 是一个可将HTMLMarkdown转为微信小程序WXML(WeiXin Markup Language)的渲染库。
用于解决在微信小程序中MarkdownHTML不能直接渲染的问题。
使用交流QQ群:182874473

特色

  • 可控制的音频播放器(可自行调节样式,解决原生audio在部分iPhone上不能自动播放的情况)
  • 支持代码语法高亮
  • 支持emoji表情😉
  • 支持上标、下标、下划线、删除线、表格、视频、图片(几乎所有html元素)……
  • 支持typographer字符替换
  • 多主题动态支持
  • 极致的中文排版优化
  • Markdown TodoList
  • 支持事件绑定(这样允许自行扩展功能哟,例如:点击页面中的某个元素,更新当前页面内容等…)
  • 前后端支持

音频播放器播放状态设定为每5秒更新一次,否则内容过多会导致性能下降

截图

以下截图即demo目录编译的效果

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-zUYN7ggi-1612616780203)(https://cdn.rawgit.com/sbfkcel/towxml/edc25e97/docs/demo.png)]

快速上手

1. 克隆TOWXML到小程序根目录 bash git clone https://github.com/sbfkcel/towxml.git

2. 在小程序app.js中引入库

//引入towxml库 App({
    onLaunch: function () {
    },
    towxml:new Towxml()                     //创建towxml对象,供小程序页面使用 }) ```

**3. 在小程序页面文件中引入模版** ```html <!--pages/index.wxml-->

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

**4. 在小程序对应的js中请求数据** ```javascript //pages/index.js

const app = getApp(); Page({
    data: {
        //article将用来存储towxml数据
        article:{}
    },
    onLoad: function () {
        const _ts = this;

        //请求markdown文件,并转换为内容
        wx.request({
            url: 'http://xxx/doc.md',
            header: {
                'content-type': 'application/x-www-form-urlencoded'
            },
            success: (res) => {
                //将markdown内容转换为towxml数据
                let data = app.towxml.toJson(
                        res.data,               // `markdown`或`html`文本内容
                        'markdown'              // `markdown`或`html`
                    );
                
                //前台初始化小程序数据(2.1.2新增,如果小程序中无相对资源需要添加`base`根地址,也无`audio`内容可无需初始化)
                data = app.towxml.initData(data,{
                    base:'https://xxx.com/',    // 需要解析的内容中相对路径的资源`base`地址
                    app:_ts                     // 传入小程序页面的`this`对象,以用于音频播放器初始化
                });

                //设置文档显示主题,默认'light'
                data.theme = 'dark';

                //设置数据
                _ts.setData({
                    article: data
                });
            }
        });
    } }) ```

**5. 引入对应的WXSS** ```css /**pages/index.wxss**/

/**基础风格样式**/ @import '/towxml/style/main.wxss';


/**如果页面有动态主题切换,则需要将使用到的样式全部引入**/

/**主题配色(浅色样式)**/ @import '/towxml/style/theme/light.wxss';

/**主题配色(深色样式)**/ @import '/towxml/style/theme/dark.wxss'; ```

OK,大功告成~~


## 事件绑定

`towxml`支持以下事件绑定,可自行根据需要为内容添加绑定事件。(不支持`bindtap`等事件简写方法)

```bash 'bind:touchstart', 'bind:touchmove', 'bind:touchcancel',
'bind:touchend', 'bind:tap',

# 2.1.0或以上的版本不支持以下事件(可自行修改`lib/tagsAndAttrs.js`中的事件解析部分,然后执行`node outTemplate.js`生成新的解析模版) 'bind:longpress', 'bind:longtap',
'bind:transitionend', 'bind:animationstart',
'bind:animationiteration', 'bind:animationend',
'bind:touchforcechange' ```

```javascript Page({   data: {
    isloading: true,
    article: {}   },   onLoad: function () {
    const _ts = this;

    //将markdown内容转换为towxml数据,交将当前页面对象传入以创建默认事件对象
    let articleData = app.towxml.toJson('<div name="button" id="button1">测试一个可点击的元素</div>', 'html');
    
    //前台初始化小程序数据(2.1.2新增,如果小程序中无相对资源需要添加`base`根地址,也无`audio`内容可无需初始化)
    articleData = app.towxml.initData(data,{
        base:'https://xxx.com/',    // 需要解析的内容中相对路径的资源`base`地址
        app:_ts                     // 传入小程序页面的`this`对象,以用于音频播放器初始化
    });

    //自定义事件,格式为`event_`+`绑定类型`+`_`+`事件类型`
    //例如`bind:touchstart`则为:
    this['event_bind_touchstart'] = (event)=>{
        console.log(event.target.dataset._el);     // 打印出元素信息
    };

    // 给todoList添加监听事件
    this['eventRun_todo_checkboxChange'] = (event)=>{
        console.log(event.detail);                 // todoList checkbox发生change事件
    };

    //设置文章数据,并清除页面loading
    _ts.setData({
        article: articleData,
        isloading: false
    });   } })

在WePY框架中使用towxml

此处以wepy 1.7.3为例,其它版本请参考


# 初始化一个项目 wepy init standard myproject

# 切换到项目目录 cd myproject

# 安装依赖 npm install

# 安装towxml npm install towxml --save

# 切换到src目录 cd src

# 克隆或下载towxml库到src目录中 git clone https://github.com/sbfkcel/towxml.git

# 将`towxml/demo/pages/wepyDemo.wpy`内容替换到`src/pages/index.wpy`

# 删除`src/towxml/`目录中未引入的文件(当然,也可不删除。需要保留的文件见上一步wepyDemo.wpy文件中的文件引入依赖)

# 开启实时编译 wepy build --watch

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

1. 依赖环境

需要 Node.js 环境。(已经安装请忽略)

2. 安装towxml bash npm install towxml

3. 接口使用 ```javascript const Towxml = require(‘towxml’); const towxml = new Towxml();

//Markdown转towxml数据 let data = towxml.toJson(’# Article
title’,‘markdown’);

//htm转towxml数据 let data = towxml.toJson(‘

Article
title

’,‘html’); ```

Demo示例

  1. towxml/demo添加为小程序工程
  2. 再克隆towxmldemo目录
  3. 使用小程序开发工具编译即可

更新说明

2.1.2

  • 调整部分资源路径
  • 为相对路径资源增加base设置支持
  • 为方便后端生成数据,将数据初始化方法分离

2.1.0

  • 增加自定义audio播放器(以解决部分播放器下audio无法播放的情况)
  • 剔除不需要的事件支持,以减少包大小

audio播放器正在播放状态每5秒更新一次界面数据(以减少多内容时频繁刷新造成的性能问题)

2.0.1

  • video、audio增加封面支持

2.0.0

  • 重写转换核心方法,更小、更快、更全、容错更高

1.5.12

  • 增加Markdown TodoList 支持

1.5.11

  • 调整事件绑定策略,剔除capture-bind绑定方式
  • 调整自定义事件时获取元素属性的方式
    • event.target.dataset._el元素的所有属性
  • 剔除data-urldata-srcdata-alphadata-iddata-name的支持(因为元素数据传递方式更全,模版代码更少)

1.5.7

  • 调整代码片段在模拟器上与真机不一至的问题

1.5.6

  • 增加事件绑定方法,允许为元素添加自定义事件

License MIT

  • 5
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
插件地址:https://github.com/kevenfeng/html-to-wxml如果前端技术比较牛,可以直接看github上面的demo。可以更好的理解用法。使用方法:1.引用插件var R_htmlToWxml = require(‘../../util/htmlToWxml.js’);//引入公共方法2.将html内容转成json数据R_htmlToWxml.html2json(“html内容”);转换后的json格式类型大概如下:3.吐到页面中显示<block wx:for="{{content}}"  wx:for-index="idy"  wx:for-item="cellData">         <block  wx:if="{{cellData.type == 'view'}}">             <view class="p">                 <block  wx:for="{{cellData.child}}" wx:key="text">                     <block  wx:if="{{item.type == 'a'}}">                         <text class="a" data-seccode="{{item.attr['data-seccode']}}" data-secname="{{item.attr['data-secname']}}" bindtap="stockClick">{{item.text}}</text>                     </block>                     <block  wx:else>                         <text>{{item.text}}</text>                     </block>                 </block>             </view>         </block>         <block wx:if="{{cellData.type == 'img'}}">             <image class="img" data-index="{{idy}}" style="height: {{cellData.attr.height?cellData.attr.height:0}}px"  mode="aspectFit" src="{{cellData.attr.src}}" bindload="imageLoad"></image>         </block>     </block>demo效果:由于小程序图片的高度没法自适应,需要给图片设置高度,所以需要在图片加载完以后,获取图片高度,等比算出显示图片高度,赋值给对应图片通常我们抓取的内容是html页面,特别是像资讯这一类的,如果在小程序里面显示文章内容,此插件提供了一种解决方案,希望对大家有用。在客户端中用native显示html页面体验上面没有native的好,htmlToWxml插件给客户端中用native的方式显示html内容提供了一种解决方案

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值