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

uni-app中使用富文本rich-text个人经验

rich-text是在uni-app一个内置组件,用于高性能地渲染富文本内容。先贴一下官方的属性列表:

uni-app富文本rich-text

先说一下“selectable” 长按选择区域复制,这个我在APP项目中 不起作用,可能像文档说的,只支持“百度小程序”吧。在APP端起作用的话,可以做如下修改,在样式中添加下面样式代码

.content-select-copy {-webkit-user-select: text;-moz-user-select: text;-ms-user-select: text;user-select: text;
}

模板中调用的时候加上面样式

 <view class="content-select-copy" ><rich-text :selectable='true'   :nodes="content"   @itemclick="handleRichText"></rich-text>
</view>

这样就可以在APP端实现长按选择区域复制了。

然后再说一下事件处理itemclick,我们可以使用这个事件实现对rich-text里面的节点内容进行处理,不过只能处理a和img标签,这个上面官方文档已经说明。

使用示例:

比如要对富文本内容中的所有链接跳到指定中转页再跳转,代码如下:

//假设我的rich-text类型为节点类型(rich-text支持节点数组或者字符串类型)
handleRichText(e){ //这里对应我上面模板中的itemclick指定的处理方法名称if(e.detail.node.name == 'a') {let url = e.detail.node.attrs.hreflet jumpurl = '/jumpurl?url='+encodeURIComponent(url )//这里我直接拉起系统浏览器访问,也可以使用 uni.navigateTo在app内部跳转this.openLink(jumpurl) }
}

对于rich-text是使用节点数组还是字符串,根据自己需求而定,如果字符串的话,可以直接写个正则替换。比如:

function replaceLinks(text) {  // 正则表达式匹配<a>标签的href属性  // 注意:这个正则表达式可能无法处理所有复杂的HTML情况  var regex = /<a\s+[^>]*href=(\"??)([^\" >]*?)(\"??)[^>]*>([^<]*)<\/a>/gi;  return text.replace(regex, function(match, quote1, url, quote2, textInside) {  // 验证URL(可选,取决于你的需求)  if (url) {  // 替换为新的链接格式  return '<a href="/jumpurl?url=' + encodeURIComponent(url) + '">' + textInside + '</a>';  }  return match;  });  
}   
content = replaceLinks(content);  

不过我建议用数组节点,后端将富文本处理为节点数组返回给前端,这样有两个好处,一是前端处理起来比较方便 ,另外一点就是性能问题,后端处理好之后,前端直接使用数组,性能会更好。这点官方文档也有说明:“nodes 值为 HTML String 时,在组件内部将自动解析为节点列表,推荐直接使用 Array 类型避免内部转换导致的性能下降”。不过要将一段HTML富文本处理成节点数组,对后端来说,也是比较麻烦的,如果使用PHP,可使用PHP DOMDocument,参考我前面的例子。PHP 转换HTML 为节点数组 – AI小站 (aisites.cn)。如果是python可以使用BeautifulSoup处理,java可以使用Jsoup

文章地址 uni-app中的富文本rich-text使用经验 – AI小站 (aisites.cn)

http://www.lryc.cn/news/376966.html

相关文章:

  • Matlab|基于V图的配电网电动汽车充电站选址定容-可视化
  • 从零开始! Jupyter Notebook的安装教程
  • web前端信息卡:深入探索与实用指南
  • 之所以选择天津工业大学,因为它是双一流、报考难度适宜,性价比高!天津工业大学计算机考研考情分析!
  • WPF三方UI库全局应用MessageBox样式(.NET6版本)
  • ABAP-03基础数据类型
  • Zabbix监控神通数据库教程
  • 5.音视频基础 FLV
  • Ubuntu server 24 (Linux) 安装客户端(windows/linux) Zabbix 7.0 LTS Zabbix agent2
  • 在 Ubuntu 上取消登录密码和锁屏功能的简易指南
  • PAT B1046. 划拳
  • 奥特曼谈AI的机遇、挑战与人类自我反思:中国将拥有独特的大语言模型
  • Java版-剑指offer数据结构与算法 视频教程 下载
  • mac禁用电池睡眠-mac盒盖连接显示器
  • 最好用的智能猫砂盆存在吗?自用分享智能猫砂盆测评!
  • LeetCode 每日一题 2748. 美丽下标对的数目
  • 全民拼购:引领商业新潮流,共创共赢新篇章
  • HarmonyOS角落里的知识:一杯冰美式的时间 -- 之打字机
  • C++ 03 之 命名空间
  • 20个国家科学数据中心(下)
  • 本地部署 Stable Diffusion3
  • 避免Tomcat调试信息泄露的最佳实践
  • Linux C++
  • Apache Doris 基础 -- 部分数据类型及操作
  • 大话C语言:第25篇 动态库
  • 数据分析:RT-qPCR分析及R语言绘图
  • 无线模块通过TCP/IP协议实现与PC端的数据传输解析
  • 嵌入式实验---实验一 通用GPIO实验
  • 中国首例!「DataKit」上架亚马逊云科技 Marketplace add-ons
  • 【博士每天一篇文献-算法】Progressive Neural Networks