Méthode de transmission : 1. Utilisez "props" dans le composant parent pour transférer les données vers le composant enfant ; 2. Le composant enfant utilise "this.$emit("event")" pour transférer les données vers le composant parent ; Utiliser des fichiers communs entre les composants frères Transmettre les données ; 4. Utilisez "ref/refs" pour transmettre les données entre les composants parents et enfants ; 5. Utilisez Vuex pour transmettre les données, etc.
L'environnement d'exploitation de ce tutoriel : système Windows 7, vue version 2.9.6, ordinateur DELL G3.
(1) Liez une propriété sur l'étiquette du composant enfant du composant parent et montez les variables à transmettre
(2) Acceptez les données via des accessoires dans le composant enfant. be Les tableaux peuvent également être des objets, et les données reçues peuvent être directement utilisées props : ["property name"] props : {property name : data type}
Exemple de code :
//父组件 <template> <p> <i>父组件</i> <!--页面使用--> <son :data='name'></son> </p> </template> <script> import son from "./son.vue";//导入父组件 export default { components: { son },//注册组件 name: "父组件", data() { return { name: "Frazier", //父组件定义变量 }; }, }; </script>
//子组件 <template> <p>{{data}}</p> </template> <script> export default { components: { }, name: '子组件', props:["data"], }; </script>
(2) Utilisez this.$emit("event") dans la méthode du composant enfant pour déclencher l'événement défini dans le composant parent. Les données sont
Exemple de code passé sous forme de paramètres :
//父组件 <template> <p> <i>父组件</i> <!--页面使用--> <son @lcclick="lcclick"></son>//自定义一个事件 </p> </template> <script> import son from "./son.vue"; //导入父组件 export default { components: { son }, //注册组件 name: "父组件", data() { return {}; }, methods: { lcclick(){ alert('子传父') } }, }; </script>
//子组件 <template> <p> <button @click="lcalter">点我</button> </p> </template> <script> export default { components: { }, name: '子组件', methods: { lcalter(){ this.$emit('lcclick')//通过emit来触发事件 } }, }; </script>
(2) Introduisez Bus.js du côté qui transmet les données, puis envoyez les événements via Bus. e m i t ("nom de l'événement", "paramètre") Les données sont distribuées par submit ("nom de l'événement", "paramètre). "). , les données sont distribuées à l'aide d'emit("event name", "parameter"), et les données sont transmises sous forme de paramètres d'emit()
(3) Introduisez Bus.js du côté qui accepte les données puis utilisez Bus.$ on("event name", (data) =>{data is the accept data})
Exemple d'image :
IV.ref/ refs (communication de composant parent-enfant) (1) Si ref est utilisé sur un élément DOM normal, la référence pointe vers l'élément DOM ; si elle est utilisée sur un sous-composant, la référence pointe vers l'instance du composant(2. ) Vous pouvez appeler directement la méthode du composant ou accéder aux données via l'instance. Cela peut également être considéré comme un moyen pour les composants enfants de transférer des valeurs aux composants parents
Exemple de code :
//父组件 <template> <p> <button @click="sayHello">sayHello</button> <child ref="childForRef"></child> </p> </template> <script> import child from './child.vue' export default { components: { child }, data () { return { childForRef: null, } }, mounted() { this.childForRef = this.$refs.childForRef; console.log(this.childForRef.name); }, methods: { sayHello() { this.childForRef.sayHello() } } } </script>
//子组件 <template> <p>child 的内容</p> </template> <script> export default { data () { return { name: '我是 child', } }, methods: { sayHello () { console.log('hello'); alert('hello'); } } } </script>
Exemple de code :
//父组件 template> <p id="app"> <ChildA/> <ChildB/> </p> </template> <script> import ChildA from './ChildA' // 导入A组件 import ChildB from './ChildB' // 导入B组件 export default { components: {ChildA, ChildB} // 注册组件 } </script>
//子组件A <template> <p id="childA"> <h1>我是A组件</h1> <button @click="transform">点我让B组件接收到数据</button> <p>因为点了B,所以信息发生了变化:{{BMessage}}</p> </p> </template> <script> export default { data() { return { AMessage: 'Hello,B组件,我是A组件' } }, computed: { BMessage() { // 这里存储从store里获取的B组件的数据 return this.$store.state.BMsg } }, methods: { transform() { // 触发receiveAMsg,将A组件的数据存放到store里去 this.$store.commit('receiveAMsg', { AMsg: this.AMessage }) } } } </script>
//子组件B <template> <p id="childB"> <h1>我是B组件</h1> <button @click="transform">点我让A组件接收到数据</button> <p>点了A,我的信息发生了变化:{{AMessage}}</p> </p> </template> <script> export default { data() { return { BMessage: 'Hello,A组件,我是B组件' } }, computed: { AMessage() { // 这里存储从store里获取的A组件的数据 return this.$store.state.AMsg } }, methods: { transform() { // 触发receiveBMsg,将B组件的数据存放到store里去 this.$store.commit('receiveBMsg', { BMsg: this.BMessage }) } } } </script>
//vuex import Vue from 'vue' import Vuex from 'vuex' Vue.use(Vuex) const state = { AMsg: '', BMsg: '' } const mutations = { receiveAMsg(state, payload) { // 将A组件的数据存放于state state.AMsg = payload.AMsg }, receiveBMsg(state, payload) { // 将B组件的数据存放于state state.BMsg = payload.BMsg } } export default new Vuex.Store({ state, mutations })
Exemple de code :
// 获父组件的数据 this.$parent.foo // 写入父组件的数据 this.$parent.foo = 2 // 访问父组件的计算属性 this.$parent.bar // 调用父组件的方法 this.$parent.baz() //在子组件传给父组件例子中,可以使用this.$parent.getNum(100)传值给父组件。
Exemple de code :
// 保存数据到 sessionStorage sessionStorage.setItem('key', 'value'); // 从 sessionStorage 获取数据 let data = sessionStorage.getItem('key'); // 从 sessionStorage 删除保存的数据 sessionStorage.removeItem('key'); // 从 sessionStorage 删除所有保存的数据 sessionStorage.clear();
//localStorage storage.set(key,val) storage.get(key, def) //sessionStorage storage.session.set(key, val) storage.session.get(key, val)
Utilisez-le lorsque la page A passe à la page A. page B. router.p u s h ( ' / B ? n a m e = d a n s e e k ' ) La page B peut utiliser ceci router.push('/B?name=danseek') La page B peut utiliser this.router.push('/B?name =danseek' )La page B peut utiliser this.route.query.name pour obtenir la valeur transmise par la page A
Veuillez noter la différence entre le routeur et la route ci-dessusUtilisez deux points pour transmettre la valeur
Configurez la route suivante :
{ path: '/b/:name', name: 'b', component: () => import( '../views/B.vue') },
Puisque la vue du routeur elle-même est également une composant, nous pouvons également utiliser le composant parent-enfant pour transmettre la valeur, puis ajouter des accessoires à la sous-page correspondante. Étant donné que la route n'est pas actualisée après la mise à jour du type, vous ne pouvez pas obtenir directement la dernière valeur de type dans le hook monté de. la sous-page, vous devez plutôt utiliser watch
.<router-view :type="type"></router-view> // 子页面 props: ['type'] watch: { type(){ // console.log("在这个方法可以时刻获取最新的数据:type=",this.type) }, },
正常情况下需要借助父亲的props作为中间过渡,但是这样在父亲组件就会多了一些跟父组件业务无关的属性,耦合度高,借助$attrs可以简化些,而且祖跟孙都无需做修改
祖组件:
<template> <section> <parent name="grandParent" sex="男" age="88" hobby="code" @sayKnow="sayKnow"></parent> </section> </template> <script> import Parent from './Parent' export default { name: "GrandParent", components: { Parent }, data() { return {} }, methods: { sayKnow(val){ console.log(val) } }, mounted() { } } </script>
父组件
<template> <section> <p>父组件收到</p> <p>祖父的名字:{{name}}</p> <children v-bind="$attrs" v-on="$listeners"></children> </section> </template> <script> import Children from './Children' export default { name: "Parent", components: { Children }, // 父组件接收了name,所以name值是不会传到子组件的 props:['name'], data() { return {} }, methods: {}, mounted() { } } </script>
子组件
<template> <section> <p>子组件收到</p> <p>祖父的名字:{{name}}</p> <p>祖父的性别:{{sex}}</p> <p>祖父的年龄:{{age}}</p> <p>祖父的爱好:{{hobby}}</p> <button @click="sayKnow">我知道啦</button> </section> </template> <script> export default { name: "Children", components: {}, // 由于父组件已经接收了name属性,所以name不会传到子组件了 props:['sex','age','hobby','name'], data() { return {} }, methods: { sayKnow(){ this.$emit('sayKnow','我知道啦') } }, mounted() { } } </script>
文字内容同第九个
祖组件
<template> <p id="app"> <children-one @eventOne="eventOne"></children-one> {{ msg }} </p> </template> <script> import ChildrenOne from '../src/components/children.vue' export default { name: 'App', components: { ChildrenOne, }, data() { return { msg: '' } }, methods: { eventOne(value) { this.msg = value } } } </script>
父组件
<template> <p> <children-two v-on="$listeners"></children-two> </p> </template> <script> import ChildrenTwo from './childrenTwo.vue' export default { name: 'childrenOne', components: { ChildrenTwo } } </script>
子组件
<template> <p> <button @click="setMsg">点击传给祖父</button> </p> </template> <script> export default { name: 'children', methods: { setMsg() { this.$emit('eventOne', '123') } } } </script>
promise 中 resolve 如何传递多个参数
//类似与这样使用,但实际上后面两个参数无法获取 promise = new Promise((resolve,reject)=>{ let a = 1 let b = 2 let c = 3 resolve(a,b,c) }) promise.then((a,b,c)=>{ console.log(a,b,c) })
resolve() 只能接受并处理一个参数,多余的参数会被忽略掉。
如果想多个用数组,或者对象方式。。
数组
promise = new Promise((resolve,reject)=>{ resolve([1,2,3]) }) promise.then((arr)=>{ console.log(arr[0],arr[1],arr[2]) })
对象
promise = new Promise((resolve,reject)=>{ resolve({a:1,b:2,c:3}) }) promise.then(obj=>{ console.log(obj.a,obj.b,obj.c) })
定义一个全局变量,在有值的组件直接赋值,在需要的组件内直接使用就可以了,具体的话看我这篇博客就可以,
博客链接点击就好 全局变量 篇
到此这篇关于vue传值方式的十二种方法总结的文章就介绍到这了,更多相关vue传值方式内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关推荐:《vue.js教程》
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!