Vue插值文本换行问题
问题背景:
后端返回的字符串带有\n换行符,但Vue将其插值渲染成div内部文本后,文本并不换行,换行符显示为一个空格。
目标:
让文本在换行符处换行。
解决方法:
思路:实现文本换行有两种方法,一是HTML方法,即<br>标签;二是CSS方法,即white-space属性。
方法1. 使用v-html
首先,将字符串里的\n替换为<br>,然后用v-html指令渲染字符串为innerHTML。
// JS部分 this.text = res.data.replace(/\n/g, '<br>') // HTML部分 <div v-html="text"></div>
这种方法比较麻烦,而且存在安全问题,故不推荐使用。
方法2. 设置white-space属性(推荐)
将div容器的white-space属性设置为pre-wrap即可解决问题。
// CSS部分
.text-wrapper { white-space: pre-wrap; }
// HTML部分
<div class="text-wrapper">{{text}}</div>
pre-wrap值的意思是保留空白并且正常换行。
white-space各属性值详见这里。其实设置为pre即可使换行符发挥作用,但这时文本在div宽度不足时不会自动换行,而是撞破边界延伸到div外部去,所以还得加上wrap。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 全程不用写代码,我用AI程序员写了一个飞机大战
· DeepSeek 开源周回顾「GitHub 热点速览」
· 记一次.NET内存居高不下排查解决与启示
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· .NET10 - 预览版1新功能体验(一)