vue component encapsulation and parent-child component value passing, event handling

In the development of vue, the part with unified function is extracted as an independent component and introduced when it is needed, which can effecti...

In the development of vue, the part with unified function is extracted as an independent component and introduced when it is needed, which can effectively reduce code redundancy
The difficulty lies in how to encapsulate, use, transfer parameters, distribute events, etc. I will use flashback to explain
(this paper is summarized in the book of Vue2 practical decryption)
The code is as follows:
Package component BookList.vue

<template> <div> <div> <div>{}</div> <div>More...</div> </div> <div> <div v-for="book in books"> <div> <img :src="book.imgUrl" /> </div> <div>{}</div> <div>{}</div> </div> </div> </div> </template> <script> export default{ props:['heading','books'], filters:{ join(args){ return args.join(','); } } } </script>
You can't use data as a data container to input data to a component. Because data is an internal object, you need to replace it with props We can understand as follows: The scope of data is only applicable to the internal, but not visible to the external. props is a public component member variable that can be seen from the internal and external

The code of the Home.vue component is as follows:

<template> <div> <book-list :books="books1" heading="Book list 1"></book-list> </div> <div> <book-list :books="books2" heading="Book list 2"></book-list> </div> </template> <script> import BookList from './components/BookList.vue' export default{ data(){ return{ books1:[], books2:[], } }, components:{ //Register custom components BookList } </script>

4 December 2019, 01:45 | Views: 6050

Add new comment

For adding a comment, please log in
or create account

0 comments