Vue 操作原生Dom refs

获取原生DOM

给标签或组件 添加ref属性

<div ref='alex'></div>
<p ref='a'></p>
<Home ref='b'></Home>

this.$refs.alex  // 获取原生的Dom对象
this.$refs.b   // 获取的是组件的实例化对象

refs属性集合

console.log(this.$refs.input);  // 获取原生DOM
// 返回值 	<input type="text">



this.$refs.input.focus(); // 操作原生dom
// 原生dom进行获取焦点操作  focus  js方法获取焦点


console.log(this.$refs.abc);  // 获取abc组件实例对象
// VueComponent {_uid: 2, _isVue: true, $options: {…}, _renderProxy: Proxy, _self: VueComponent, …}


// 获取abc子组件的父组件,这里就是当前组件
console.log(this.$refs.abc.$parent);  // 获取父组件 


// 获取abc组件的根组件,也就是原始Vue
console.log(this.$refs.abc.$root); // 获取最原始的Vue 根


// 获取当前组件的子组件,是个列表集合
console.log(this.$children);  // 获取儿子组件

一个测试例子

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
<div id="app">

</div>

<script src="../vue.js"></script>
<script>
    Vue.component('Test', {
        data: function () {
            return {}
        },
        template: `
            <div>我是测试组件</div>
        `
    });

    Vue.component('Test2', {
        data: function () {
            return {}
        },
        template: `
            <div>我是测试组件2</div>
        `
    });

    let App = {
        data: function () {
            return {}
        },
        template: `
            <div>
                <input type="text" ref="input">
                <Test ref="abc"/>
                <Test2 ref="efg"/>
            </div>
        `,
        mounted: function () {
            console.log(this.$refs.input);  // 获取原生DOM
            // 原生dom进行获取焦点操作  focus  js方法获取焦点
            this.$refs.input.focus();
            console.log(this.$refs.abc);  // 获取abc组件实例对象
            console.log(this.$refs.abc.$parent);  // 获取父组件
            console.log(this.$refs.abc.$root); // 获取最原始的Vue 根
            console.log(this.$children)  // 获取儿子组件

            // for (let key in this.$refs){
            //     console.log(this.$refs[key]);
            // }
        }
    };

    let vm = new Vue({
        el: '#app',
        data: function () {
            return {}
        },
        template: `
        <App />
        `,
        components: {
            App
        }
    });
</script>
</body>
</html>
posted @ 2019-12-27 18:40  Hyyyy  阅读(682)  评论(0编辑  收藏  举报