Vue插值文本换行问题

26 篇文章 0 订阅

问题背景:

后端返回的字符串带有\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。

  • 4
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Vue中要实现导出Excel文本换行,可以通过在文本内容中添加换行符(`\n`)来实现。 例如,假设我们有一个包含多行文本的数据数组。我们可以使用`map`方法遍历数组,对每个文本进行处理,将每行文本的末尾添加`\n`换行符。 具体代码如下: ``` exportToExcel() { // 假设有一个包含文本的数组 const data = [ { text: '第一行文本' }, { text: '第二行文本' }, { text: '第三行文本' }, ]; // 将每个文本的末尾添加换行符 const textWithLineBreak = data.map(item => item.text + '\n'); // 创建一个CSV格式的字符串 const csvContent = 'data:text/csv;charset=utf-8,' + textWithLineBreak.join(''); // 创建一个链接,并模拟点击下载 const encodedUri = encodeURI(csvContent); const link = document.createElement('a'); link.setAttribute('href', encodedUri); link.setAttribute('download', 'data.csv'); document.body.appendChild(link); link.click(); } ``` 这段代码首先将每个文本的末尾添加了`\n`换行符,并将其保存在`textWithLineBreak`数组中。然后,通过将这个数组使用`join`方法连接成一个CSV格式的字符串。 接下来,代码创建了一个链接,并设置链接的`href`属性为这个CSV字符串的编码URI,设置链接的`download`属性为要导出的Excel文本的文件名(此处为`data.csv`)。 最后,将链接添加到文档中,并模拟点击下载链接,实现Excel文本的导出。 这样,导出的Excel文本中的每行文本就会自动换行显示。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值