在 Vue 中将数据从子组件传递到父组件
2017-05-20
3380
我正在练习 Vue JS,想了解如何将数据从子组件传递到发出事件的父组件。 这是我的父组件 BookList:
<template>
<div class="booklist">
<BookForm @book-is-created="onClickForm" />
<table v-for="book in books">
<tr>
<th> Author </th>
<th> Title </th>
<th> Publishing House </th>
<th> Edition Date </th>
</tr>
<tr>
<td> {{ book.author}}</td>
<td> {{ book.title}}</td>
<td> {{ book.publishing_house}}</td>
<td> {{ book.edition_date}}</td>
</tr>
</table>
</div>
</template>
<script>
import BookForm from './BookForm';
export default {
name: 'hello',
data: () => ({
books: []
}),
mounted() {
axios.get("http://localhost:3000/api/v1/books")
.then(response => {this.books = response.data})
},
components:{
BookForm
},
methods:{
onClickForm(){
console.log(this.book)
console.log('Book created')
}
}
}
</script>
这是我的 BookForm 组件的代码,我将从中输入书籍数据并更新发出“book-is-created”和书籍对象的 BookList:
<template lang="html">
<form>
<label for="author">Author</label>
<input v-model="book.author"type="text" name="author" value="">
<br>
<label for="title">Title</label>
<input v-model="book.title" type="text" name="title" value="">
<br>
<label for="publishing_house">Publishing house</label>
<input v-model="book.publishing_house" type="text" name="publishing_house" value="">
<br>
<label for="edition_date">Edition Date</label>
<input v-model="book.edition_date" type="text" name="edition_date" value="">
<br>
<button v-on:click.prevent="createBook" >createBook</button>
</form>
</template>
<script>
export default {
data:() =>({
book:{
author:"",
title:"",
publishing_house: "",
edition_date: ""
}
}),
methods:{
createBook: function() {
//console.log(this.book)
this.$emit('book-is-created', this.book)
}
}
}
</script>
当尝试控制台记录书籍对象时,它返回“未定义”。如何在 BookList 组件中提供书籍对象以更新我的列表?
1个回答
代码将 book 作为
book-is-created
事件的参数传递,但您的处理程序不接受该参数。您需要做的就是将
book
作为参数添加到您的处理程序,然后您就可以在方法中使用它。
methods:{
onClickForm(book){
console.log(book)
console.log('Book created')
// this.books.push(book)
}
}
另外请注意,避免使用箭头函数定义
data
。您当前的代码没问题,但如果您曾尝试在数据函数中使用
this
,
this
将引用错误的内容。只需使用典型函数或新方法语法即可。
data(){
return {
book:{
author:"",
title:"",
publishing_house: "",
edition_date: ""
}
}
}
Bert
2017-05-20