当前位置: 首页 > backend >正文

uniapp解析富文本,视频无法显示问题

1. uniapp解析富文本,视频无法显示问题

  rich-text 无法处理 video,uni-app 文档中关于 rich-text 介绍中明确说明 rich-text 支持什么(参考文档),其中并不包含 video 。

1.1. 解决办法

  在uni-app插件市场搜索parse插件使用。
  parse插件有很多,包含的功能也不尽相同。
  我播放 video 时使用的是uParse 富文本解析。
在这里插入图片描述

1.1.1. uParse 富文本解析插件的使用

  (1)在项目中导入插件。这步不详述了。不会的需要补补关于uniapp的使用知识。导入成功后,多出目录项目根目录/components/u-parse。
  (2)在页面中导入插件。

import uParse from '@/components/u-parse/u-parse.vue';

  (3)替换rich-text

<!-- <rich-text :nodes="content"></rich-text> -->
<u-parse :content="content" />

1.1.2. 处理 vedio 标签样式

  默认的vedio样式需要修改时,可以使用正则表达式替换。。
  (1)新建 js 文件 : richTextUtil.js

语法说明
标题文本样式列表图片链接目录代码片表格注脚注释自定义列表LaTeX 数学公式插入甘特图插入UML图插入Mermaid流程图插入Flowchart流程图插入类图快捷键
代码片复制

下面展示一些 内联代码片

/*** 处理富文本里的图片宽度自适应* 1.去掉img、video标签里的style、width、height属性* 2.修改所有style里的width属性为max-width:100%* 3.img、video标签添加style属性:max-width:100%;height:auto* 4.去掉<br/>标签* @param html* @return string*/
function formatRichText (html) {// 去掉img标签里的style、width、height属性let newContent= html.replace(/<img[^>]*>/gi,function(match,capture){match = match.replace(/style="[^"]+"/gi, '').replace(/style='[^']+'/gi, '');match = match.replace(/width="[^"]+"/gi, '').replace(/width='[^']+'/gi, '');match = match.replace(/height="[^"]+"/gi, '').replace(/height='[^']+'/gi, '');return match;});// 去掉video标签里的style、width、height属性newContent= html.replace(/<video[^>]*>/gi,function(match,capture){match = match.replace(/style="[^"]+"/gi, '').replace(/style='[^']+'/gi, '');match = match.replace(/width="[^"]+"/gi, '').replace(/width='[^']+'/gi, '');match = match.replace(/height="[^"]+"/gi, '').replace(/height='[^']+'/gi, '');return match;});// 修改所有style里的width属性为max-width:100%// 去掉所有style里的font-size属性newContent = newContent.replace(/style="[^"]+"/gi,function(match,capture){match = match.replace(/width:[^;]+;/gi, 'max-width:100%;').replace(/width:[^;]+;/gi, 'max-width:100%;');match = match.replace(/font-size:[^;]+;/gi, '');return match;});// 去掉<br/>标签newContent = newContent.replace(/<br[^>]*\/>/gi, '');// img标签添加style属性:max-width:100%;height:autonewContent = newContent.replace(/\<img/gi, '<img style="max-width:100%;height:auto;display:block;margin:0px auto;"');// video标签添加style属性:max-width:100%;height:autonewContent = newContent.replace(/\<video/gi, '<video style="max-width:100%;height:auto;display:block;margin:0px auto;"');return newContent;
}export default {formatRichText,
};

  (2)引入js库

import richTextUtil from '@/common/richTextUtil.js';

  (3)调用方法

this.content = richTextUtil.formatRichText(res.content);
http://www.xdnf.cn/news/19143.html

相关文章:

  • 网络初识及网络编程
  • WPF中的ref和out
  • Shell 秘典(卷三)——循环运转玄章 与 case 分脉断诀精要
  • 访问Nginx 前端页面,接口报502 Bad Gateway
  • 软考 系统架构设计师系列知识点之杂项集萃(137)
  • 如何在 Jenkins Docker 容器中切换到 root 用户并解决权限问题
  • 深入理解 RabbitMQ:从底层原理到实战落地的全维度指南
  • C++之stack类的代码及其逻辑详解
  • 基于DCT-FFT的图像去噪滤波算法
  • GD32入门到实战22--红外NEC通信协议
  • 超越传统SEO:用生成引擎优化(GEO)驱动下一轮增长
  • Tomcat 企业级运维实战系列(三):Tomcat 配置解析与集群化部署
  • UI前端大数据可视化实战策略:如何设计符合用户认知的数据可视化界面?
  • JUC并发编程10 - 内存(02) - volatile
  • vscode terminal远程连接linux服务器GUI图形界面
  • 鸿蒙NEXT布局全解析:从线性到瀑布流,构建自适应UI界面
  • 深入理解计算机端口:为什么通信需要端口?
  • 【读论文】质心重分配显微镜实现活样本超分辨成像
  • Qt中的QSS介绍
  • Time-MOE添加MLP分类头进行分类任务
  • 用户自定义字段(Custom Fields)设计方案,兼顾多语言、分组、校验、权限、查询性能、审计与多租户
  • 创维E910V10C_晶晨S905L2和S905L3芯片_线刷固件包
  • HDMI2.1 8K验证平台
  • 【拍摄学习记录】05-对焦、虚化、景深
  • 告别音色漂移!微软超长语音合成模型VibeVoice正式开源​
  • 数列寻方:等差数列和为完全平方数
  • MinIO社区版“背刺“之后:RustFS用Apache 2.0协议重构开源信任
  • Java接口和抽象类的区别,并举例说明
  • 【Spring Cloud Alibaba】前置知识(一)
  • LeetCode 01背包 494. 目标和