Свойство todo
успешно очищено, проблема в событии вставки, вы должны очистить его, добавив событие blur
:
onPaste: function(event){
let clipped = event.clipboardData.getData('text').split("\n");
clipped.forEach(item => {
this.todos.push({
text: item, done: false
})
})
this.todo = ''
event.target.blur();
}
Полный пример
new Vue({
el: "#app",
data: {
todo: '',
todos: [{
text: "Learn JavaScript",
done: false
},
{
text: "Learn Vue",
done: false
},
{
text: "Play around in JSFiddle",
done: true
},
{
text: "Build something awesome",
done: true
}
]
},
methods: {
toggle: function(todo) {
todo.done = !todo.done
},
addTodo: function() {
this.todos.push({
text: this.todo,
done: false
})
this.todo = ''
},
onPaste: function(event) {
let clipped = event.clipboardData.getData('text').split("\n");
clipped.forEach(item => {
this.todos.push({
text: item,
done: false
})
})
// is not clearing the v-model: todo
this.todo = ''
event.target.blur();
}
}
})
body {
background: #20262E;
padding: 20px;
font-family: Helvetica;
}
#app {
background: #fff;
border-radius: 4px;
padding: 20px;
transition: all 0.2s;
}
li {
margin: 8px 0;
}
h2 {
font-weight: bold;
margin-bottom: 15px;
}
del {
color: rgba(0, 0, 0, 0.3);
}
<script src="https://cdnjs.cloudflare.com/ajax/libs/vue/2.5.17/vue.js"></script>
<div id="app">
<h2>Todos:</h2>
<input type="text" v-model="todo" @keyup.enter="addTodo" @paste="onPaste">
<ol>
<li v-for="todo in todos">
<label>
<input type="checkbox"
v-on:change="toggle(todo)"
v-bind:checked="todo.done">
<del v-if="todo.done">
{{ todo.text }}
</del>
<span v-else>
{{ todo.text }}
</span>
</label>
</li>
</ol>
</div>