uni-app开发微信小程序,如何使用towxml去渲染md格式和html标签格式的内容?

uni-app开发微信小程序,如何使用towxml去渲染md格式和html标签格式的内容?

前言

一次偶然的面试,面试官问到,你有没有用过towxml?

我:没有。

于是面试结束后,就开始在百度查了,查到了它的githup地址towxml地址,然后就把代码拉下来,好好扒开看看。

最终做出了一个来渲染面试题答案的组件,实现了一个刷面试题的小程序。

先看效果

下面这个截图是从蝌蚪智汇 小程序里面截出来的,有兴趣的可以去看看

如何在项目中使用towxml

第一步

先在项目的根目录创建一个wxcomponents的文件夹,然后把towxml的源码放进去,如下图所示

第二步

直接引入towxml方法使用,完整代码如下:

javascript 复制代码
<template>
	<view class="md-view">
		<!-- 页面头部 -->
		<cu-custom bgColor="bg-gradual-pink" :isBack="true" :isCustomBackFn="true">
			<block slot="backText">返回</block>
			<block slot="content">md文档展示</block>
		</cu-custom>
		<towxml :nodes="html" />
	</view>
</template>

<script>
	import towxml from "@/wxcomponents/towxml/index.js";
	import { text, htmlText } from './md-text.js';
	
	export default {
		name: 'md-view',
		data(){
			return {
				html: ''
			}
		},
		mounted() {
			// 还可以直接渲染html代码towxml(htmlText, 'html')
			this.html = towxml(text, 'markdown')
			console.log(this.html);
		}
	}
</script>

<style lang="scss" scoped>
</style>

md-text.js文件代码:

javascript 复制代码
export const text = `

## 渲染 code 方法, 如下

\`\`\`html
<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title></title>
</head>

<body>
  
</body>
</html>

<script>

</script>

\`\`\`
`

export const htmlText =
	"<p style=\"line-height: 2;\"><span style=\"font-family: Pacifico;\">当一个Vue实例创建时,Vue会遍历</span><strong style=\"font-family: Pacifico;\">data</strong><span style=\"font-family: Pacifico;\">中的属性,用 </span><strong style=\"font-family: Pacifico;\">Object.defineProperty</strong><span style=\"font-family: Pacifico;\">(vue3.0使用proxy )将它们转为 </span><strong style=\"font-family: Pacifico;\">getter/setter</strong><span style=\"font-family: Pacifico;\">,并且在内部追踪相关依赖,在属性被访问和修改时通知变化。 每个组件实例都有相应的 </span><strong style=\"font-family: Pacifico;\">watcher </strong><span style=\"font-family: Pacifico;\">程序实例,它会在组件渲染的过程中把属性记录为依赖,之后当依赖项的setter被调用时,会通知watcher重新计算,从而致使它关联的组件得以更新。</span></p>"

总结

towxml使用起来倒是不难,但有的效果展示还是不太理想,可以去改改源码达到你想要的效果哦

关注我不迷路

不定期发表前端开发技巧类的文章

相关推荐
CHB5 小时前
uni-agent,你的数字员工来了
人工智能·uni-app·vibecoding
h_jQuery5 小时前
uniapp使用canvas实现逐字书写任意文字内容,后合成一张图片提交
前端·javascript·uni-app
困困的果果头5 小时前
【uniapp】解决H5嵌套在web-view中时打包页面与状态栏重叠
前端·uni-app
前端 贾公子5 小时前
Uniapp 使用 UQRCode 创建二维码
uni-app
Rattenking5 小时前
uni-app组件开发----自定义数字键盘组件
前端·javascript·uni-app
竟未曾年少轻狂5 小时前
微信小程序-组件开发
微信小程序·小程序
我命由我123456 小时前
React - 组件优化、children props 与 render props、错误边界
前端·javascript·react.js·前端框架·html·ecmascript·js
李宏伟~6 小时前
大文件分片案例html + nodejs + 视频上传案例
javascript·html·音视频
ZC跨境爬虫6 小时前
海南大学交友平台登录页开发实战day3(解决python传输并读取登录信息的问题)
前端·数据库·python·html