Rumah >hujung hadapan web >Soal Jawab bahagian hadapan >Bagaimana untuk menghantar nilai kepada komponen vue

Bagaimana untuk menghantar nilai kepada komponen vue

青灯夜游
青灯夜游asal
2023-01-06 17:26:162482semak imbas

Kaedah hantaran nilai: 1. Gunakan prop untuk menghantar daripada ibu bapa kepada anak; 2. Hantar daripada anak kepada ibu bapa, anda perlu menyesuaikan acara, gunakan "this.$emit('event name')" untuk mencetuskannya dalam komponen anak, dan Gunakan "@nama acara" dalam ibu bapa untuk mendengar 3. Antara saudara, gunakan elemen ibu bapa awam sebagai jambatan, gabungkan prop ibu bapa dan anak untuk lulus parameter, dan acara tersuai anak dan ibu bapa; 4. Gunakan laluan untuk menghantar nilai; untuk lulus, dsb.

Bagaimana untuk menghantar nilai kepada komponen vue

Persekitaran pengendalian tutorial ini: sistem windows7, versi vue3, komputer DELL G3.

Artikel ini akan membincangkan 10 cara untuk memindahkan nilai dalam komponen Vue. Terdapat juga lima atau enam kaedah yang biasa digunakan. Mari kita mulakan dengan gambar ringkasan:

Bagaimana untuk menghantar nilai kepada komponen vue

1. Hantarkan komponen induk kepada komponen anak

Tentukan prop dalam komponen anak, iaitu prop: ['msg'], msg can be Objek juga boleh menjadi jenis data asas

Jika anda ingin mentakrifkan nilai lalai, iaitu prop:{msg: {type: String, default: 'hello world'}} ,
Jika nilai lalai ialah jenis objek :props: { msg: { type: Object, default: () => { return { name: 'dan_seek' } } }}

Ia sepatutnya ambil perhatian bahawa pemindahan nilai ini adalah sehala Nilai komponen induk tidak boleh diubah (kecuali untuk jenis rujukan, sudah tentu); dan jika nilai prop diubah suai secara langsung, amaran akan dilaporkan.

Cara yang disyorkan untuk menulisnya ialah dengan mentakrifkan semula pembolehubah dalam data() (lihat Children.vue) dan menetapkan prop padanya, sifat yang dikira juga akan berfungsi.

Children.vue

<template>
    <section>
        父组件传过来的消息是:{{myMsg}}
    </section>
</template>

<script>
    export default {
        name: "Children",
        components: {},
        props:[&#39;msg&#39;],
        data() {
            return {
                myMsg:this.msg
            }
        },
        methods: {}
    }
</script>

Parent.vue

<template>
  <div class="parent">
    <Children :msg="message"></Children>
  </div>
</template>

<script>
import Children from &#39;../components/Children&#39;

export default {
  name: &#39;Parent&#39;,
  components: {
      Children
  },
  data() {
      return {
          message:&#39;hello world&#39;
}
},
}
</script>

2

Anda perlu menggunakan acara tersuai di sini, gunakan ini.$emit('myEvent') dalam komponen anak untuk mencetuskan, dan kemudian gunakan @myEvent dalam komponen induk untuk mendengar

Children.vue

<template>
    <div class="parent">
        这里是计数:{{parentNum}}
        <Children-Com @addNum="getNum"></Children-Com>
    </div>
</template>

<script>
    import ChildrenCom from &#39;../components/Children&#39;

    export default {
        name: &#39;Parent&#39;,
        components: {
            ChildrenCom
        },
        data() {
            return {
                parentNum: 0
            }
        },
        methods:{
            // childNum是由子组件传入的
            getNum(childNum){
                this.parentNum = childNum
            }
        }
    }
</script>

Ibu bapa.vue

<template>
    <div>
        这里是计数:{{parentNum}}
        <children-com></children-com>
    </div></template><script>
    import ChildrenCom from &#39;../components/Children&#39;

    export default {
        name: &#39;Parent&#39;,
        components: {
            ChildrenCom        },
        data() {
            return {
                parentNum: 0
            }
        },
        methods:{
            // childNum是由子组件传入的
            getNum(childNum){
                this.parentNum = childNum            }
        }
    }</script>

3 Menggunakan acara tersuai

keupayaan pencetus dan pemantauan emit menentukan bas acara awam, eventBus, yang melaluinya kita boleh menghantar nilai kepada mana-mana komponen melaluinya sebagai jambatan perantaraan. Dan melalui penggunaan eventBus, anda boleh memperdalam pemahaman anda tentang emit. EventBus.js

Children1.vue
import Vue from &#39;vue&#39;
export default new Vue()

Children2.vue
<template>
    <section>
        <div @click="pushMsg">push message</div>
        <br>
    </section>
</template>

<script>
    import eventBus from &#39;./EventBus&#39;
    export default {
        name: "Children1",
        components: {},
        data() {
            return {
                childNum:0
            }
        },
        methods: {
            pushMsg(){
            	// 通过事件总线发送消息
                eventBus.$emit(&#39;pushMsg&#39;,this.childNum++)
            }
        }
    }
</script>

Ibu bapa.vue
<template>
    <section>
        children1传过来的消息:{{msg}}
    </section>
</template>

<script>
    import eventBus from &#39;./EventBus&#39;

    export default {
        name: "Children2",
        components: {},
        data() {
            return {
                msg: &#39;&#39;
            }
        },
        mounted() {
        	// 通过事件总线监听消息
            eventBus.$on(&#39;pushMsg&#39;, (children1Msg) => {
                this.msg = children1Msg
            })
        }
    }
</script>

Terdapat juga perpustakaan vue-bus sumber terbuka pada github, anda boleh merujuknya: https://github.com/yangmingshan/vue-bus#readme
<template>
    <div class="parent">
        <Children1></Children1>
        <Children2></Children2>
    </div>
</template>

<script>
    import Children1 from &#39;../components/Children1&#39;
    import Children2 from &#39;../components/Children2&#39;

    export default {
        name: &#39;Parent&#39;,
        components: {
            Children1,
            Children2
        },
        data() {
            return {
            }
        },
        methods:{
        }
    }
</script>

4 , lulus nilai antara laluan

i .$router apabila halaman A melompat ke halaman B. .push('/B?name=danseek')Halaman B boleh menggunakan ini.$route.query.name untuk mendapatkan nilai yang dihantar dari halaman A

Perhatikan penghala dan laluan di atas Perbezaannya ialah

ii Gunakan titik bertindih untuk menghantar nilai

untuk mengkonfigurasi laluan berikut: boleh dilalui di halaman B ini.$route.params.name untuk mendapatkan nilai nama yang dihantar melalui laluan

{
    path: &#39;/b/:name&#39;,
    name: &#39;b&#39;,
    component: () => import( &#39;../views/B.vue&#39;)
  },

iii. Gunakan komponen induk-anak untuk menghantar nilai

Disebabkan penghala -View sendiri juga merupakan komponen, jadi kami juga boleh menggunakan kaedah pemindahan nilai komponen induk-anak untuk lulus nilai, dan kemudian tambah prop pada sub-halaman yang sepadan Oleh kerana laluan tidak dimuat semula selepas jenis dikemas kini, ia tidak boleh diperoleh secara langsung daripada cangkuk yang dipasang pada sub-halaman, sebaliknya gunakan menonton.

5 Gunakan $ref untuk menghantar nilai
<router-view></router-view>
// 子页面
......
props: [&#39;type&#39;]
......
watch: {
            type(){
                // console.log("在这个方法可以时刻获取最新的数据:type=",this.type)
            },
        },
Gunakan keupayaan $ref untuk mentakrifkan ID untuk komponen anak dan induk. komponen boleh menggunakan ID ini untuk Akses terus kaedah dan sifat dalam komponen anak

Mula-mula tentukan komponen kanak-kanak Children.vue

dan kemudian rujuk Children.vue dalam komponen induk Ibu bapa .vue dan tentukan atribut ref

<template>
    <section>
        传过来的消息:{{msg}}
    </section>
</template>

<script>
    export default {
        name: "Children",
        components: {},
        data() {
            return {
                msg: &#39;&#39;,
                desc:&#39;The use of ref&#39;
            }
        },
        methods:{
            // 父组件可以调用这个方法传入msg
            updateMsg(msg){
                this.msg = msg
            }
        },
    }
</script>

6 Gunakan suntikan pergantungan untuk menyampaikannya kepada keturunan dan cicit
<template>
    <div class="parent">
        <!-- 给子组件设置一个ID ref="children" -->
        <Children ref="children"></Children>
        <div @click="pushMsg">push message</div>
    </div>
</template>

<script>
    import Children from &#39;../components/Children&#39;

    export default {
        name: &#39;parent&#39;,
        components: {
            Children,
        },
        methods:{
            pushMsg(){
                // 通过这个ID可以访问子组件的方法
                this.$refs.children.updateMsg(&#39;Have you received the clothes?&#39;)
                // 也可以访问子组件的属性
                console.log(&#39;children props:&#39;,this.$refs.children.desc)
            }
        },
    }
</script>

Anggapkan. bahawa komponen induk mempunyai kaedah getName(), yang perlu disediakan Kepada semua keturunan berikan pilihan membolehkan kami menentukan data/kaedah yang ingin kami sediakan kepada komponen keturunan

Kemudian dalam mana-mana komponen keturunan, kita boleh menggunakan

untuk Menyuntik data/kaedah komponen induk ke dalam contoh semasa:
provide: function () {
  return {
    getName: this.getName()
  }
}

Parent.vue

inject

Kanak-kanak .vue
inject: [&#39;getName&#39;]

<template>
    <div class="parent">
        <Children></Children>
    </div>
</template>

<script>
    import Children from &#39;../components/Children&#39;

    export default {
        name: &#39;Parent&#39;,
        components: {
            Children,
        },
        data() {
            return {
                name:&#39;dan_seek&#39;
            }
        },
        provide: function () {
            return {
                getName: this.name
            }
        },
    }
</script>

7 Cucu nenek moyang $attrs


<script>
    export default {
        name: "Children",
        components: {},
        data() {
            return {
            }
        },
        inject: [&amp;#39;getName&amp;#39;],
    }
</script>

Biasanya, anda perlu menggunakan prop bapa sebagai peralihan perantaraan, tetapi dengan cara ini, komponen bapa akan mempunyai beberapa sifat yang tidak ada kaitan dengan perniagaan komponen induk, dan tahap gandingan Tinggi, ia boleh dipermudahkan dengan bantuan $attrs, dan nenek moyang mahupun cucu tidak perlu membuat pengubahsuaianGrandParent.vue

Parent.vue

Children.vue
<template>
    <section>
        <parent name="grandParent" sex="男" age="88" hobby="code" @sayKnow="sayKnow"></parent>
    </section>
</template>

<script>
    import Parent from &#39;./Parent&#39;
    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 &#39;./Children&#39;

  export default {
    name: "Parent",
    components: {
      Children
    },
    // 父组件接收了name,所以name值是不会传到子组件的
    props:[&#39;name&#39;],
    data() {
      return {}
    },
    methods: {},
    mounted() {
    }
  }
</script>

Paparan keputusan

<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:[&#39;sex&#39;,&#39;age&#39;,&#39;hobby&#39;,&#39;name&#39;],
    data() {
      return {}
    },
    methods: {
      sayKnow(){
        this.$emit(&#39;sayKnow&#39;,&#39;我知道啦&#39;)
      }
    },
    mounted() {
    }
  }
</script>
8. Sun Chuanzu
父组件收到
祖父的名字:grandParent
子组件收到
祖父的名字:
祖父的性别:男
祖父的年龄:88
祖父的爱好:code

Dengan bantuan $pendengar Untuk acara perantaraan, cucu boleh memberitahu nenek moyang dengan mudah. Untuk contoh kod, lihat 7 Kemudian melalui contoh ini, anda boleh mengakses sifat dan kaedah komponen induk Ia juga mempunyai akar saudara, yang boleh mendapatkan contoh komponen akar.

语法:

// 获父组件的数据
this.$parent.foo

// 写入父组件的数据
this.$parent.foo = 2

// 访问父组件的计算属性
this.$parent.bar

// 调用父组件的方法
this.$parent.baz()

于是,在子组件传给父组件例子中,可以使用this.$parent.getNum(100)传值给父组件。

10、sessionStorage传值

sessionStorage 是浏览器的全局对象,存在它里面的数据会在页面关闭时清除 。运用这个特性,我们可以在所有页面共享一份数据。

语法:

// 保存数据到 sessionStorage
sessionStorage.setItem(&#39;key&#39;, &#39;value&#39;);

// 从 sessionStorage 获取数据
let data = sessionStorage.getItem(&#39;key&#39;);

// 从 sessionStorage 删除保存的数据
sessionStorage.removeItem(&#39;key&#39;);

// 从 sessionStorage 删除所有保存的数据
sessionStorage.clear();

注意:里面存的是键值对,只能是字符串类型,如果要存对象的话,需要使用 let objStr = JSON.stringify(obj) 转成字符串然后再存储(使用的时候 let obj = JSON.parse(objStr) 解析为对象)。

这样存对象是不是很麻烦呢,推荐一个库 good-storage ,它封装了sessionStorage ,可以直接用它的API存对象

// localStorage
 storage.set(key,val) 
 storage.get(key, def)
 
 // sessionStorage
 storage.session.set(key, val)
 storage.session.get(key, val)

更多请移步:https://github.com/ustbhuangyi/storage#readme

【相关推荐:vuejs视频教程web前端开发

Atas ialah kandungan terperinci Bagaimana untuk menghantar nilai kepada komponen vue. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn