小程序rich-text组件如何改变内部img图片样式的方法


Posted in Javascript onMay 22, 2019

一、起因

小程序中有一个页面,很奇葩,是通过后端传过来的整段HTML字符串展示内容的,那么我们暂时叫这个页面为content,传过来之后,他里面的图片样式是不固定的,有的大,有的小,有的有style有的没有,那我怎么能让他统一展示成一样的样式呢?

二、办法

思前想后,我觉得还是正则比较靠谱,把content里面所有的img标签筛选出来,把里面有style的、有width的、有height的、全部删除掉,最后在统一加上我们想要的样式,最终代码如下:

<RichText nodes={content} />

下面是HTML字符串处理过程

let html = content
      .replace(/<p([\s\w"=\/\.:;]+)((?:(style="[^"]+")))/ig, '<p')
      .replace(/<p>/ig, '<p style="font-size: 15Px; line-height: 25Px;">')
      .replace(/<img([\s\w"-=\/\.:;]+)((?:(height="[^"]+")))/ig, '<img$1')
      .replace(/<img([\s\w"-=\/\.:;]+)((?:(width="[^"]+")))/ig, '<img$1')
      .replace(/<img([\s\w"-=\/\.:;]+)((?:(style="[^"]+")))/ig, '<img$1')
      .replace(/<img([\s\w"-=\/\.:;]+)((?:(alt="[^"]+")))/ig, '<img$1')
      .replace(/<img([\s\w"-=\/\.:;]+)/ig, '<img$1 style="width: 100%; border-radius: 8Px;"');

最终实现了我们想要的样式统一的效果啦~

三、总结

我有想过直接在less里面取到img,然后改变它的样式,这种办法在h5中是可行的,但是在小程序中不起作用!因为在小程序中会是一整个rich-text标签,里面的内容样式无法修改。所以采用这种办法啦~~能够解决问题。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
htm调用JS代码
Mar 15 Javascript
使用javascript实现有效时间的控制,并显示将要过期的时间
Jan 02 Javascript
javascript获取flash版本号的方法
Nov 20 Javascript
JavaScript原生xmlHttp与jquery的ajax方法json数据格式实例
Dec 04 Javascript
JavaScript+CSS无限极分类效果完整实现方法
Dec 22 Javascript
node.js连接mongoDB数据库 快速搭建自己的web服务
Apr 17 Javascript
JQuery的attr 与 val区别
Jun 12 Javascript
jQuery焦点图轮播效果实现方法
Dec 19 Javascript
Vue项目添加动态浏览器头部title的方法
Jul 11 Javascript
微信小程序时间轴实现方法示例
Jan 14 Javascript
微信小程序 组件的外部样式externalClasses使用详解
Sep 06 Javascript
vue实现全屏滚动效果(非fullpage.js)
Mar 07 Javascript
JavaScript中的 new 命令
May 22 #Javascript
element-ui组件中input等的change事件中传递自定义参数
May 22 #Javascript
原生JS实现列表内容自动向上滚动效果
May 22 #Javascript
小程序如何使用分包加载的实现方法
May 22 #Javascript
原生js实现trigger方法示例代码
May 22 #Javascript
koa router 多文件引入的方法示例
May 22 #Javascript
微信小程序template模板与component组件的区别和使用详解
May 22 #Javascript
You might like
php zip文件解压类代码
2009/12/02 PHP
10个超级有用值得收藏的PHP代码片段
2015/01/22 PHP
使用php-timeit估计php函数的执行时间
2015/09/06 PHP
PHP中JSON的应用技巧
2015/10/10 PHP
laravel 5.1下php artisan migrate的使用注意事项总结
2017/06/07 PHP
php 猴子摘桃的算法
2017/06/20 PHP
php 中phar包的使用教程详解
2018/10/26 PHP
仿校内登陆框,精美,给那些很厉害但是没有设计天才的程序员
2008/11/24 Javascript
yepnope.js 异步加载资源文件
2011/09/08 Javascript
jQuery动态添加 input type=file的实现代码
2012/06/14 Javascript
js弹出模式对话框,并接收回传值的方法
2013/03/12 Javascript
js控制frameSet示例
2013/09/10 Javascript
使用js解决由border属性引起的div宽度问题
2013/11/26 Javascript
JavaScript从数组的indexOf()深入之Object的Property机制
2016/05/11 Javascript
学习JavaScript图片预加载模块
2016/11/07 Javascript
easyui datagrid 大数据加载效率慢,优化解决方法(推荐)
2016/11/09 Javascript
利用js+css+html实现固定table的列头不动
2016/12/08 Javascript
从零开始做一个pagination分页组件
2017/03/15 Javascript
Vue的MVVM实现方法
2017/08/16 Javascript
详解angularJS+Ionic移动端图片上传的解决办法
2017/09/13 Javascript
在vue中使用vue-echarts-v3的实例代码
2018/09/13 Javascript
vue视图不更新情况详解
2019/05/16 Javascript
vue2配置scss的方法步骤
2019/06/06 Javascript
JS监听组合按键思路及实现过程
2020/04/17 Javascript
[53:20]2018DOTA2亚洲邀请赛 4.1 小组赛 A组加赛 VG vs OG
2018/04/03 DOTA
python中的列表推导浅析
2014/04/26 Python
使用IronPython把Python脚本集成到.NET程序中的教程
2015/03/31 Python
Python中的Classes和Metaclasses详解
2015/04/02 Python
Python实现动态加载模块、类、函数的方法分析
2017/07/18 Python
基于使用paramiko执行远程linux主机命令(详解)
2017/10/16 Python
Python 序列化和反序列化库 MarshMallow 的用法实例代码
2020/02/25 Python
HTML5中通过li-canvas轻松实现单图、多图、圆角图绘制,单行文字、多行文字等
2018/11/30 HTML / CSS
计算机应用职专应届生求职信
2013/11/12 职场文书
公司规章制度范本
2015/08/03 职场文书
用Python简陋模拟n阶魔方
2021/04/17 Python
关于vue中如何监听数组变化
2021/04/28 Vue.js