微信小程序實現(xiàn)動態(tài)渲染Markdown示例詳解
需求
十幾個圖文編排的介紹文章,每個頁面的結構、內容都不相同,
因此沒有辦法通過WXML代碼把文章結構固定下來。
因此筆者想到的解決方案包括:
- 全部轉成長截圖,好處是代碼超級簡單,壞處是:即使只改一個字,也要重新生成、上傳截圖
- 全部用原生小程序硬編碼出來,每個介紹文章寫一個組件。雖然后期修改靈活,但過于低效且麻煩。
考慮到對于圖文編排來說,markdown的效率遠高于HTML,如果有辦法把markdown文檔渲染成小程序頁面,以上的需求就能很好的解決。
查了一下,還真有,倉庫地址:Towxml
構建
名字非常簡單粗暴:to wxml,就是把markdown或HTML轉換成WXML。
作者說這個包不建議從NPM上獲取,而應該自己使用源碼構建:
// clone倉庫 git clone https://github.com/sbfkcel/towxml.git // 進入文件夾 cd towxml // 安裝依賴 npm install // 構建 npm run build
構建完成后,把dist文件夾復制到小程序的/miniprogram/
路徑下(和app.ts、pages等目錄同級):
在小程序的app.ts
中添加towxml:require('/towxml/index')
:
/** * app.ts * TS小程序的App泛型可能和引入的組件不兼容,可以改成any */ App<any>({ globalData: {}, towxml:require('/towxml/index'), onLaunch() { }, })
在需要使用的頁面json中添加組件引用:
{ "usingComponents": { "towxml":"/towxml/towxml" } }
頁面V層(wxml文件):
<!--index.wxml--> <view class="container"> <towxml nodes="{{article}}"/> </view>
頁面C層(ts文件):
//獲取應用實例 const app = getApp(); // data中添加兩個變量 Page({ data: { isLoading: true, // 判斷是否尚在加載中 article: {} // 內容數(shù)據 }, })
使用
官方文檔鏈接:鏈接
文檔中寫到,在onload方法中初始化,就可以渲染markdown文本了,最終作用在上文寫的towxml標簽上:
onLoad: function () { let result = app.towxml('# Markdown', 'markdown',{ base:'https://xxx.com', // 相對資源的base路徑 theme:'light', // 主題,默認`light` events:{ // 為元素綁定的事件方法 tap:(e)=>{ console.log('tap',e); } } }); // 更新解析數(shù)據 this.setData({ article:result, isLoading: false }); }
towxml方法的三個參數(shù):
- 文本型,必填。就是實際需要渲染的文本,上述代碼的
#Markdown
渲染出來就是一級標題 - 文本型,必填。表示類型,本文只用到markdown所以寫'markdown'即可
- 對象,必填。表示渲染時的參數(shù),具體可以看文檔,比如,主題可以改成亮色或暗色。
接下來需要解決一個問題:
上述代碼的markdown文本是直接寫在代碼里的,實際應用肯定需要從后端獲取
因此先寫一個獲取文本的方法:
// 獲取markdown文本 getText: (url, callback) => { wx.request({ url: url, header: { 'content-type': 'application/x-www-form-urlencoded' }, success: (res) => { if (typeof callback === 'function') { callback(res); }; } }); },
然后改寫一下原來的onload:
onLoad: function () { // 獲取文本,第一個參數(shù)指向后端的文件地址(你需要起一個后端) this.getText('http://127.0.0.1:8080/test.md', res => { // 回調函數(shù)中完成更新數(shù)據的邏輯 let result = app.towxml(res.data, 'markdown',{ base:'https://xxx.com', theme:'light', events:{ tap:(e)=>{ console.log('tap',e); } } }); // 更新解析數(shù)據 this.setData({ article:result, isLoading: false }); }) }
此時就可以渲染來自HTTP的markdown文件了:
最后通過參數(shù)修改請求地址就可以靈活控制頁面中的文本了。
總結
如果用傳統(tǒng)方式,真的把十幾篇二十幾篇文章做成頁面,沒個一兩天寫不完。用markdown渲染的方式一個小時應該就能結束戰(zhàn)斗,效率起飛。
作為程序員,能動腦子的事情,絕對不用重復勞動,能用自動化解決的問題,絕對不動手。
以上就是微信小程序實現(xiàn)動態(tài)渲染Markdown示例詳解的詳細內容,更多關于微信小程序動態(tài)渲染Markdown的資料請關注腳本之家其它相關文章!
- python使用html2text庫實現(xiàn)從HTML轉markdown的方法詳解
- python 自動化將markdown文件轉成html文件的方法
- Python?mistune庫靈活的Markdown解析器使用實例探索
- Python自動創(chuàng)建Markdown表格使用實例探究
- uniapp中解析markdown支持網頁和小程序實現(xiàn)示例
- 一款功能強大的markdown編輯器tui.editor使用示例詳解
- umi插件開發(fā)仿dumi項目加載markdown文件實現(xiàn)詳解
- unified如何處理markdown解析器詳解
- python markdown轉html自定義實現(xiàn)工具解析
相關文章
兼容IE和Firefox火狐的上下、左右循環(huán)無間斷滾動JS代碼
html里的marqueen也能實現(xiàn)內容的滾動,但滾動是間斷的,運用JavaScript可以使這一問題得到改觀,實現(xiàn)無間斷的滾動,讓頁面看起來更美觀2013-04-04使用Promise和JavaScript有效處理1000個請求的方法
在現(xiàn)代Web開發(fā)中,處理高并發(fā)請求是一個常見的挑戰(zhàn),當我們需要從服務器獲取大量數(shù)據或執(zhí)行多個異步任務時,如何有效地管理請求的并發(fā)性和性能變得至關重要,本文將介紹如何使用Promise和JavaScript來管理高并發(fā)請求,需要的朋友可以參考下2023-09-09JS中Generator函數(shù)與async函數(shù)用法介紹
javascript中經常會用到異步編程,在ES6之后我們使用的?Generator函數(shù)、async函數(shù)、promise都是我們異步編程的一大助力,這里我們主要講解Generator、async函數(shù),并且簡介他們之間的一些聯(lián)系,本篇文章會帶著一些簡易案例,方便大家理解使用2023-06-06Bootstrap 模態(tài)框多次顯示后臺提交多次BUG的解決方法
本篇文章主要介紹了Bootstrap 模態(tài)框多次顯示后臺提交多次BUG的解決方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-12-12