Uniapp
的过程中遇到了富文本的显示,对比了 微信小程序
中生成的代码,才发现原来微信官方早就开发了<rich-text>
标签,可以很方便的拿来使用wxml
页面元素的最简单使用 <rich-text nodes="{{article_content}}"></rich-text>
文章 ID
,网络请求其文章内容;然后将 "html"
格式的代码进行转化;最后赋值于 article_content
变量./**
* 此代码段处理目的为,匹配富文本代码中的 <img> 标签,并将其图片的宽度修改为适应屏幕
* max-width:100% --- 图片宽度加以限制,避免超出屏幕
* height:auto --- 高度自适应
* display:block --- 此代码,可以去掉图片之间的空白间隔,个人觉得好用
*/
article_content = article_content.replace(/<img/gi, '<img style="max-width:100%;height:auto;display:block" ');
一般而言,我们使用的富文本编辑器(比如:UEditor),生成的
HTML节点及属性
大多数都可以进行解析 测试中,发现对<section>
标签不支持 可参考文章: 小程序 rich-text 不支持 section 标签的情况
article_content = article_content.replace(/<img/gi, '<img style="max-width:100%;height:auto;display:block" ')
.replace(/<section/g, '<div')
.replace(/\/section>/g, '\div>');