网站首页 > 博客文章 正文
rich-text是在uni-app一个内置组件,用于高性能地渲染富文本内容。先贴一下官方的属性列表:
先说一下“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.href
let 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,参考我前面的例子。uni-app中的富文本rich-text使用经验 AI小站。如果是python可以使用BeautifulSoup处理,java可以使用Jsoup。
猜你喜欢
- 2025-01-15 uniapp之导航栏文字显示不全
- 2025-01-15 万能前端框架uni app初探03:底部导航开发
- 2025-01-15 uniapp开发注意事项(建议)
- 2025-01-15 一款制作励志标语的小程序,使用uniapp+canvas合成
- 2025-01-15 uni-app 启动
- 2025-01-15 低代码可视化-uniapp响应式数据data-代码生成器
- 2025-01-15 uni-app的基本使用
- 2025-01-15 小程序海报生成神器之一lime-painter配合uniapp简单使用示例
你 发表评论:
欢迎- 367℃用AI Agent治理微服务的复杂性问题|QCon
- 358℃初次使用IntelliJ IDEA新建Maven项目
- 357℃手把手教程「JavaWeb」优雅的SpringMvc+Mybatis整合之路
- 351℃Maven技术方案最全手册(mavena)
- 348℃安利Touch Bar 专属应用,让闲置的Touch Bar活跃起来!
- 346℃InfoQ 2024 年趋势报告:架构篇(infoq+2024+年趋势报告:架构篇分析)
- 345℃IntelliJ IDEA 2018版本和2022版本创建 Maven 项目对比
- 342℃从头搭建 IntelliJ IDEA 环境(intellij idea建包)
- 最近发表
- 标签列表
-
- powershellfor (55)
- messagesource (56)
- aspose.pdf破解版 (56)
- promise.race (63)
- 2019cad序列号和密钥激活码 (62)
- window.performance (66)
- qt删除文件夹 (72)
- mysqlcaching_sha2_password (64)
- ubuntu升级gcc (58)
- nacos启动失败 (64)
- ssh-add (70)
- jwt漏洞 (58)
- macos14下载 (58)
- yarnnode (62)
- abstractqueuedsynchronizer (64)
- source~/.bashrc没有那个文件或目录 (65)
- springboot整合activiti工作流 (70)
- jmeter插件下载 (61)
- 抓包分析 (60)
- idea创建mavenweb项目 (65)
- vue回到顶部 (57)
- qcombobox样式表 (68)
- vue数组concat (56)
- tomcatundertow (58)
- pastemac (61)
本文暂时没有评论,来添加一个吧(●'◡'●)