vue / 微信小程序实现富文本(richtext)图片宽度自适应

这篇文章介绍了如何使用JavaScript工具richText.js处理微信小程序中的富文本内容,实现图片宽度自适应,去除不必要的style属性并调整img标签样式。
摘要由CSDN通过智能技术生成

vue / 微信小程序实现富文本(richtext)图片宽度自适应

  • 工具 richText.js
/**
 * 处理富文本里的图片宽度自适应
 * 1.去掉img标签里的style、width、height属性
 * 2.img标签添加style属性:max-width:100%;height:auto
 * 3.修改所有style里的width属性为max-width:100%
 * 4.去掉<br/>标签
 * @param html
 * @returns {void|string|*}
 */
function formatRichText(html, p_class = "fsmp") {
	if (!html) {
		return ''
	}

	let newContent = html
	if (html.indexOf("<img") != -1) {
		newContent = html.replace(/<img[^>]*>/gi, function (match, capture) {
			match = match.replace(/style="[^"]+"/gi, "").replace(/style='[^']+'/gi, "")
			match = match.replace(/style=""/gi, "")
			match = match.replace(/width="[^"]+"/gi, "").replace(/width='[^']+'/gi, "")
			match = match.replace(/height="[^"]+"/gi, "").replace(/height='[^']+'/gi, "")
			return match
		})
		newContent = newContent.replace(/style="[^"]+"/gi, function (match, capture) {
			match = match.replace(/width:[^;]+;/gi, "max-width:100%;").replace(/width:[^;]+;/gi, "max-width:100%;")
			return match
		})
		newContent = newContent.replace(/<br[^>]*\/>/gi, "")
		newContent = newContent.replace(/\<img/gi, '<img style="max-width:100%;height:auto;display:block;margin-top:0;margin-bottom:0;"')
	}

	newContent = newContent.replace(/<br[^>]*\/>/gi, "")
	newContent = newContent.replace(/<a>/gi, `<a class="${p_class} p_class_color "`)
	newContent = newContent.replace(/<li>/gi, `<li class="${p_class} p_class_color "`)
	newContent = newContent.replace(/\<p/gi, `<p class="${p_class} p_class_color "`)
	newContent = newContent.replace(/\<span/gi, `<span class="${p_class} p_class_color "`)

	return newContent
}

module.exports = {
	formatRichText
}


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值