第一种方法
直接在子组件中通过this.$parent.event来调用父组件的方法
父组件
01 | <template> |
02 | <div> |
03 | <child></child> |
04 | </div> |
05 | </template> |
06 | <script> |
07 | import child from './components/dam/child' ; |
08 | export default { |
09 | components: { |
10 | child |
11 | }, |
12 | methods: { |
13 | fatherMethod() { |
14 | console.log( '测试' ); |
15 | } |
16 | } |
17 | }; |
18 | </script> |
01 | <template> |
02 | <div> |
03 | <button @click= "childMethod()" >点击</button> |
04 | </div> |
05 | </template> |
06 | <script> |
07 | export default { |
08 | methods: { |
09 | childMethod() { |
10 | this .$parent.fatherMethod(); |
11 | } |
12 | } |
13 | }; |
14 | </script> |
在子组件里用$emit向父组件触发一个事件,父组件监听这个事件就行了。
父组件
01 | <template> |
02 | <div> |
03 | <child @fatherMethod= "fatherMethod" ></child> |
04 | </div> |
05 | </template> |
06 | <script> |
07 | import child from '~/components/dam/child' ; |
08 | export default { |
09 | components: { |
10 | child |
11 | }, |
12 | methods: { |
13 | fatherMethod() { |
14 | console.log( '测试' ); |
15 | } |
16 | } |
17 | }; |
18 | </script> |
01 | <template> |
02 | <div> |
03 | <button @click= "childMethod()" >点击</button> |
04 | </div> |
05 | </template> |
06 | <script> |
07 | export default { |
08 | methods: { |
09 | childMethod() { |
10 | this .$emit( 'fatherMethod' ); |
11 | } |
12 | } |
13 | }; |
14 | </script> |
父组件把方法传入子组件中,在子组件里直接调用这个方法
父组件
01 | <template> |
02 | <div> |
03 | <child :fatherMethod= "fatherMethod" ></child> |
04 | </div> |
05 | </template> |
06 | <script> |
07 | import child from '~/components/dam/child' ; |
08 | export default { |
09 | components: { |
10 | child |
11 | }, |
12 | methods: { |
13 | fatherMethod() { |
14 | console.log( '测试' ); |
15 | } |
16 | } |
17 | }; |
18 | </script> |
01 | <template> |
02 | <div> |
03 | <button @click= "childMethod()" >点击</button> |
04 | </div> |
05 | </template> |
06 | <script> |
07 | export default { |
08 | props: { |
09 | fatherMethod: { |
10 | type: Function, |
11 | default : null |
12 | } |
13 | }, |
14 | methods: { |
15 | childMethod() { |
16 | if ( this .fatherMethod) { |
17 | this .fatherMethod(); |
18 | } |
19 | } |
20 | } |
21 | }; |
22 | </script> |
01 | <template> |
02 | <div> |
03 | <button @click= "fatherMethod()" >点击</button> |
04 | </div> |
05 | </template> |
06 | <script> |
07 | export default { |
08 | props: { |
09 | fatherMethod: { |
10 | type: Function, |
11 | default : null |
12 | } |
13 | }, |
14 | methods: { |
15 | |
16 | } |
17 | }; |
18 | </script> |