文章详情

  • 游戏榜单
  • 软件榜单
关闭导航
热搜榜
热门下载
热门标签
php爱好者> php教程>vue有哪三种传值方式

vue有哪三种传值方式

时间:2021-09-14  来源:互联网

今天PHP爱好者给大家带来vue三种传值方式:1、“父传子”;父组件通过prop给子组件下发数据(传值)。2、“子传父”;子组件通过“事件”给父组件发送消息。3、“非父子传值”;非父子组件之间需要定义个公共的公共实例文件“bus.js”,作为中间仓库来传值。希望对大家有所帮助。

本教程操作环境:windows7系统、vue2.9.6版,DELL G3电脑。

Vue常用的三种传值方式:

  • 父传子

  • 子传父

  • 非父子传值

引用官网一句话:父子组件的关系可以总结为 prop 向下传递,事件向上传递。父组件通过 prop 给子组件下发数据,子组件通过事件给父组件发送消息。

1、父组件向子组件传值:

父组件:

<template>
 <p>
   父组件:
   <input type="text" v-model="name">
   <br>
   <br>
   <!-- 引入子组件 -->
   <child :inputName="name"></child>
 </p>
</template>
<script>
import child from './child'
export default {
   components: {
     child
   },
   data () {
     return {
       name: ''
     }
   }
 }
</script>

子组件:

<template>
 <p>
   子组件:
   <span>{{inputName}}</span>
 </p>
</template>
<script>
 export default {
   // 接受父组件的值
   props: {
     inputName: String,
     required: true
   }
 }
</script>

2、子组件向父组件传值:

子组件:

<template>
 <p>
   子组件:
   <span>{{childValue}}</span>
   <!-- 定义一个子组件传值的方法 -->
   <input type="button" value="点击触发" @click="childClick">
 </p>
</template>
<script>
 export default {
   data () {
     return {
       childValue: '我是子组件的数据'
     }
   },
   methods: {
     childClick () {
       // childByValue是在父组件on监听的方法
       // 第二个参数this.childValue是需要传的值
       this.$emit('childByValue', this.childValue)
     }
   }
 }
</script>

父组件:

<template>
 <p>
   父组件:
   <span>{{name}}</span>
   <br>
   <br>
   <!-- 引入子组件 定义一个on的方法监听子组件的状态-->
   <child v-on:childByValue="childByValue"></child>
 </p>
</template>
<script>
 import child from './child'
 export default {
   components: {
     child
   },
   data () {
     return {
       name: ''
     }
   },
   methods: {
     childByValue: function (childValue) {
       // childValue就是子组件传过来的值
       this.name = childValue
     }
   }
 }
</script>

3、非父子组件传值:

  非父子组件之间传值,需要定义个公共的公共实例文件bus.js,作为中间仓库来传值,不然路由组件之间达不到传值的效果。

公共  bus.js

//bus.js
import Vue from 'vue'
export default new Vue()

组件A:

<template>
 <p>
   A组件:
   <span>{{elementValue}}</span>
   <input type="button" value="点击触发" @click="elementByValue">
 </p>
</template>
<script>
 // 引入公共的bug,来做为中间传达的工具
 import Bus from './bus.js'
 export default {
   data () {
     return {
       elementValue: 4
     }
   },
   methods: {
     elementByValue: function () {
       Bus.$emit('val', this.elementValue)
     }
   }
 }
</script>

组件B:

<template>
 <p>
   B组件:
   <input type="button" value="点击触发" @click="getData">
   <span>{{name}}</span>
 </p>
</template>
<script>
 import Bus from './bus.js'
 export default {
   data () {
     return {
       name: 0
     }
   },
   mounted: function () {
     var vm = this
     // 用$on事件来接收参数
     Bus.$on('val', (data) => {
       console.log(data)
       vm.name = data
     })
   },
   methods: {
     getData: function () {
       this.name++
     }
   }
 }
</script>

以上就是vue有哪三种传值方式的详细内容,更多请关注php爱好者其它相关文章!

相关阅读更多 +
最近更新
排行榜 更多 +
元梦之星最新版手游

元梦之星最新版手游

棋牌卡牌 下载
我自为道安卓版

我自为道安卓版

角色扮演 下载
一剑斩仙

一剑斩仙

角色扮演 下载