Heim  >  Artikel  >  Web-Frontend  >  Was bedeutet vue $on?

Was bedeutet vue $on?

藏色散人
藏色散人Original
2020-12-03 10:15:195060Durchsuche

„$on“ bezieht sich in Vue auf eine Methode mit einer Syntax wie „Event.$on('msg',function(msg){...}“, wobei der erste Parameter der Name der Daten ist, die ist derselbe wie beim Senden. Entsprechend dem Namen ist der zweite Parameter eine Methode, die mit Daten arbeitet

Was bedeutet vue $on?

Die Betriebsumgebung dieses Tutorials: Windows 7-System, Vue Version 2.0, Dell G3-Computer

Empfohlen: „vue-Tutorial“ 》$emit und $on

  var Event = new Vue();      
相当于又new了一个vue实例,Event中含有vue的全部方法;
  Event.$emit('msg',this.msg);      
发送数据,第一个参数是发送数据的名称,接收时还用这个名字接收,第二个参数是这个数据现在的位置;
  Event.$on('msg',function(msg){  
接收数据,第一个参数是数据的名字,与发送时的名字对应,第二个参数是一个方法,要对数据的操作
    /这里是对数据的操作
  })

in

vue Beispiel:

<!DOCTYPE html>
<html>
    <head>
        <meta charset="utf-8" />
        <title>孙三峰--博客园</title>
        <script type="text/javascript" src="js/vue2.0.3.js" ></script>
        <script type="text/javascript">
            //准备一个空的实例对象
            var Event = new Vue();
            var A={
                template:`
                    <div style="border: 1px solid red; margin-bottom: 10px; width: 300px;">
                        <h4>A组件</h4>
                        <p>{{a}}</p>
                        <input type="button" value="把A数据给C" @click="send" />
                    </div>
                `,
                data(){
                    return {
                        a:&#39;我是A里面的数据&#39;
                    }
                },
                methods:{
                    send(){        //A发送数据
                        Event.$emit(&#39;a-msg&#39;,this.a);
                    }
                }
            };
            var B={
                template:`
                    <div style="border: 1px solid green; margin-bottom: 10px; width: 300px;">
                        <h4>B组件</h4>
                        <p>{{b}}</p>
                        <input type="button" value="把B数据给C" @click="send" />
                    </div>
                `,
                data(){
                    return {
                        b:&#39;我是B里面的数据&#39;
                    }
                },
                methods:{
                    send(){
                        Event.$emit(&#39;b-msg&#39;,this.b);
                    }
                }
            };
            var C={
                template:`
                    <div style="border: 1px dotted green; margin-bottom: 10px;width: 300px;">
                        <h4>我是C组件,我在坐等接收数据</h4>
                        <p>{{a}}</p>
                        <p>{{b}}</p>
                    </div>
                `,
                data(){
                    return{
                        a:&#39;&#39;,
                        b:&#39;&#39;
                    }
                },
                mounted(){        //两种接收的方式
                    var _this = this;
                    Event.$on(&#39;a-msg&#39;,function(a){
                        _this.a=a;
                    });
                    Event.$on(&#39;b-msg&#39;,function(b){
                        this.b = b;
                    }.bind(this))
                }
            };
            window.onload=function(){
                new Vue({
                    el:&#39;#box&#39;,
                    data:{

                    },
                    components:{
                        &#39;com-a&#39;:A,
                        &#39;com-b&#39;:B,
                        &#39;com-c&#39;:C
                    }
                })
            }
        </script>
    </head>
    <body>
        <div id="box">
            <com-a></com-a>
            <com-b></com-b>
            <com-c></com-c>
        </div>
    </body>
</html>

Rendering:

Was bedeutet vue $on?

Das obige ist der detaillierte Inhalt vonWas bedeutet vue $on?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn