中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

vue中ref怎么用

vue
清風
3455
2021-03-15 10:23:03
欄目: 編程語言

vue中ref怎么用

vue中ref的用法有三種,分別是:1.ref加在普通的元素上,用this.ref.name獲取dom元素;2.ref加在子組件上,用this.ref.name 獲取組件實例,可以使用組件的所有方法;3.利用v-for和ref獲取一組數組或者dom節點。

示例:

1.ref使用在外面的組件上。

<div id="ref-outside-component" v-on:click="consoleRef">

    <component-father ref="outsideComponentRef">

    </component-father>

    <p>ref在外面的組件上</p>

</div>

    var refoutsidecomponentTem={

        template:"<div class='childComp'><h5>我是子組件</h5></div>"

    };

    var refoutsidecomponent=new Vue({

        el:"#ref-outside-component",

        components:{

            "component-father":refoutsidecomponentTem

        },

        methods:{

            consoleRef:function () {

                console.log(this); // #ref-outside-component     vue實例

                console.log(this.$refs.outsideComponentRef);  // div.childComp vue實例,組件實例

            }

        }

    });

2.ref作用在外面元素上。

//ref在外面的元素上

<div id="ref-outside-dom" v-on:click="consoleRef" >

   <component-father>

   </component-father>

   <p ref="outsideDomRef">ref在外面的元素上</p>

</div>

    var refoutsidedomTem={

        template:"<div class='childComp'><h5>我是子組件</h5></div>"

    };

    var refoutsidedom=new Vue({

        el:"#ref-outside-dom",

        components:{

            "component-father":refoutsidedomTem

        },

        methods:{

            consoleRef:function () {

                console.log(this); // #ref-outside-dom    vue實例

                console.log(this.$refs.outsideDomRef);  //  <p>標簽dom元素 ref在外面的元素上</p>

            }

        }

    });

3.ref使用在里面的元素上,局部注冊組件。

//ref在里面的元素上

<div id="ref-inside-dom">

    <component-father>

    </component-father>

    <p>ref在里面的元素上</p>

</div>

    var refinsidedomTem={

        template:"<div class='childComp' v-on:click='consoleRef'>" +

                       "<h5 ref='insideDomRef'>我是子組件</h5>" +

                  "</div>",

        methods:{

            consoleRef:function () {

                console.log(this);  // div.childComp   vue實例 

                console.log(this.$refs.insideDomRef);  // <h5 >我是子組件</h5>

            }

        }

    };

    var refinsidedom=new Vue({

        el:"#ref-inside-dom",

        components:{

            "component-father":refinsidedomTem

        }

    });

4.ref使用在里面的元素上,全局注冊組件。

//ref在里面的元素上--全局注冊

<div id="ref-inside-dom-all">

    <ref-inside-dom-quanjv></ref-inside-dom-quanjv>

</div>

    Vue.component("ref-inside-dom-quanjv",{

        template:"<div class='insideFather'> " +

                    "<input type='text' ref='insideDomRefAll' v-on:input='showinsideDomRef'>" +

                    "  <p>ref在里面的元素上--全局注冊 </p> " +

                  "</div>",

        methods:{

            showinsideDomRef:function () {

                console.log(this); //這里的this其實還是div.insideFather

                console.log(this.$refs.insideDomRefAll); // <input  type="text">

            }

        }

    });

    var refinsidedomall=new Vue({

        el:"#ref-inside-dom-all"

    });


0
德清县| 宁河县| 吉林省| 饶平县| 贺州市| 建始县| 黎川县| 衢州市| 长沙县| 买车| 虞城县| 临汾市| 福鼎市| 石景山区| 濮阳市| 石家庄市| 海丰县| 白银市| 荣昌县| 莒南县| 仙桃市| 监利县| 普定县| 丹江口市| 蒲江县| 自治县| 高雄市| 黄大仙区| 阿勒泰市| 乌什县| 石泉县| 邻水| 英德市| 和林格尔县| 云龙县| 东方市| 民权县| 英超| 自治县| 尚志市| 玛沁县|