在Vue.js中,当按下回车键时,在文本输出中添加一个<br>标签

In Vue.js, when the enter key is pressed, add a <br> tag to the text output

我需要向应用添加一些基本的文本编辑器功能。
我有一个文本区域,当用户输入内容时,文本会输出到一个段落中。我正在监听空格键并在该文本区域上输入按键以触发方法。
当在文本区域中按下回车键时,我希望文本输出也有一个换行符,但我得到

this.textBody.appendChild is not a function

这就是我正在尝试的:

new Vue({
  el: "#app",
  data: {
    title: "",
    textBody: ""
  },
  methods: {
    logSpacebar: function(){
      console.log("spacebar pressed");
      //Fire corrector API?
    },
    logEnter: function(){
      console.log("pressed enter");
      var breakTag = document.createElement("br");
      this.textBody.appendChild(breakTag);
    }
  }
})

对应的html(部分):

<input type="text" v-model="title"/>
<textarea name="" cols="30" rows="10" v-model="textBody" v-on:keyup.space="logSpacebar" v-on:keyup.enter="logEnter"></textarea>
<h2>Title: {{title}}</h2>
<p>Text body: {{textBody}}</p>

我会避免在 Vue 中自己手动更新 DOM。相反,使用计算 属性 结合 v-html.

console.clear()

new Vue({
  el: "#app",
  data:{
    textBody: "type some text\nwith returns interspersed\nin this textarea"
  },
  computed:{
    parsedBody(){
      return this.textBody.replace(/\n/g,"<br>")
    }
  }
})
<script src="https://unpkg.com/vue@2.4.2"></script>
<div id="app">
  <textarea v-model="textBody" cols="80" rows="10"></textarea>
  <hr>
  <p v-html="parsedBody"></p>
</div>