vue父子组件之间怎么传值?下面本篇文章带大家了解一下Vue中父组件以及子组件传值问题,希望对大家有所帮助!
前言:在一些页面中不单单的纯纯的一个vue文件,vue讲究组件化开发,但是一般的肯定会产生交互事件,今天了解了这个传值,特此的来记录一下。
一.父组件向子组件传值
父组件向子组件传值会用到:Prop,一般的我们需要在子组件中进行相关的声明,如下所示:
(资料图片)
子组件为HellowWorld.vue
<script>export default { name: "HelloWorld", //接收的变量 props: { //声明相关的类型 msg: String, count:Number, options:[] }, data(){ return{ } }, methods:{ }}</script>
登录后复制
在父组件App.vue中
<script>//引入组件import HelloWorld from "./components/HelloWorld.vue"export default { name: "App", components: { HelloWorld }, data(){ return{ count:0, options:[], } }, methods:{ }}</script>
登录后复制
那么在页面上效果就是:当然我们也可以写一些事件来进行动态的数据交互,例如:
二.子组件向父组件传值
在子组件传值时会用到$emit,值得注意的是:在子组件传值时候的方法要与父组件中监听的方法名称相同,也就是示例中的 listenToChild。 【相关推荐:vuejs视频教程、web前端开发】
Helloworld.vue子组件:
{{ msg }}
{{count}}
- {{item}}
<script>export default { name: "HelloWorld", props: { msg: String, count:Number, options:[] }, data(){ return{ } }, methods:{ SendMsg(){ // listenToChild 注意 this.$emit("listenToChild",this.options) } }}</script>
登录后复制
App.vue父组件:
- {{index}},{{item}}
<script>import HelloWorld from "./components/HelloWorld.vue"export default { name: "App", components: { HelloWorld }, data(){ return{ // 要传去子组件的参数 count:0, options:[], // 子组件传来的参数 data:[] } }, methods:{ Add(){ this.count=Number(this.count)+1 this.options.push("添加一次,当前数值为:"+this.count) }, Sub(){ if(this.count<=0){ this.options.push("当前数值不能变化了"+this.count) }else{ this.count=Number(this.count)-1 this.options.pop() } }, show(data){ console.log(data) this.data=data }, restart(){ this.count=0 this.options=[] } }}</script>
登录后复制
效果:
(学习视频分享:vuejs入门教程、编程基础视频)
以上就是一文浅析Vue中父子组件间传值问题的详细内容,更多请关注php中文网其它相关文章!