vue中的ref其实功能很强大,下面介绍一下如何使用。

基本用法,本页面获取dom元素

<template>
<div id="app">
<div ref="testDom">11111</div>
<button @click="getTest">获取test节点</button>
</div>
</template>

<script>
export default {
methods: {
getTest() {
console.log(this.$refs.testDom)
}
}
};
</script>

vue中ref的作用_简书 image

其实ref除了可以获取本页面的dom元素,还可以拿到子组件中的data和去调用子组件中的方法

获取子组件中的data

子组件

<template>
<div>
{{ msg }}
</div>
</template>

<script>
export default {
data() {
return {
msg: "hello world"
}
}
}
</script>

父组件

<template>
<div id="app">
<HelloWorld ref="hello"/>
<button @click="getHello">获取helloworld组件中的值</button>
</div>
</template>

<script>
import HelloWorld from "./components/HelloWorld.vue";

export default {
components: {
HelloWorld
},
data() {
return {}
},
methods: {
getHello() {
console.log(this.$refs.hello.msg)
}
}
};
</script>

vue中ref的作用_简书_02 image

调用子组件中的方法

子组件

<template>
<div>
</div>
</template>

<script>
export default {
methods: {
open() {
console.log("调用到了")
}
}
}
</script>

父组件

<template>
<div id="app">
<HelloWorld ref="hello"/>
<button @click="getHello">获取helloworld组件中的值</button>
</div>
</template>

<script>
import HelloWorld from "./components/HelloWorld.vue";

export default {
components: {
HelloWorld
},
data() {
return {}
},
methods: {
getHello() {
this.$refs.hello.open();
}
}
};
</script>

vue中ref的作用_商业_03 image

子组件调用父组件方法

子组件

<template>
<div>
</div>
</template>

<script>
export default {
methods: {
open() {
console.log("调用了");
// 调用父组件方法
this.$emit("refreshData");
}
}
}
</script>

父组件

<template>
<div id="app">
<HelloWorld ref="hello" @refreshData="getData"/>
<button @click="getHello">获取helloworld组件中的值</button>
</div>
</template>

<script>
import HelloWorld from "./components/HelloWorld.vue";

export default {
components: {
HelloWorld
},
data() {
return {}
},
methods: {
getHello() {
this.$refs.hello.open()
},
getData() {
console.log('111111')
}
}
};
</script>

vue中ref的作用_商业_04 image

作者:回不去的那些时光

著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。