打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
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。

本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
Vue3 模板语法 | 菜鸟教程
Vue指令学习文档
如何在 IE6,7 下实现 white-space: pre-wrap;
在网页中显示文本 (JavaScript)
CSS3属性之五:text-overflow
Vue基础(一):Vue的概述与基本使用
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服