在Vue中动态插入HTML需用v-html指令渲染安全的HTML字符串,或配合v-pre跳过编译、用计算属性预处理、render函数构造VNode、mounted中操作innerHTML。

在Vue应用中,若需将动态数据作为HTML内容直接插入到页面中,而非以纯文本形式显示,则需要使用特定的模板语法与指令来实现。以下是完成此任务的具体方法:
一、使用v-html指令渲染HTML内容
v-html指令用于更新元素的innerHTML,它会将绑定的值作为HTML解析并渲染,而不是作为普通文本。该指令可替代插值表达式{{ }}对HTML字符串的转义行为,适用于已确认安全的富文本内容。
1、在Vue实例或组件的data选项中定义包含HTML标签的字符串,例如:content: ' 这是加粗段落
2、在模板中使用v-html绑定该数据属性:。
立即学习“前端免费学习笔记(深入)”;
3、确保该HTML字符串不来自不可信用户输入,否则可能引发XSS攻击。
二、使用v-pre跳过编译节点
v-pre指令用于跳过Vue对其所在节点及其所有子节点的编译过程,常用于展示原始模板语法或避免对含HTML结构的静态内容进行不必要的响应式处理。
1、在需要原样输出HTML代码的容器上添加v-pre属性: {{ message }} 不会被编译
2、若配合v-html使用,可用于防止Vue对v-html内部的插值表达式进行二次解析,例如:。
三、通过计算属性预处理HTML字符串
当HTML内容需基于响应式数据动态生成时,可借助计算属性对原始数据进行过滤、拼接或格式化,再交由v-html渲染,从而增强可控性与安全性。
1、在Vue实例的computed选项中定义计算属性,返回处理后的HTML字符串:formattedContent() { return ' ' + this.body + '' + this.title + '
2、在模板中绑定该计算属性:。
还木有评论哦,快来抢沙发吧~