获取vue 框架的页面dom 元素,还可以拿到注册的组件实例,也是父组件获取了子组件的值和方法!!!
ref 有三种用法:
1、ref 加在普通的元素上,用this.ref.name 获取到的是dom元素
2、ref 加在子组件上,用this.ref.name 获取到的是组件实例,可以使用组件的所有方法。
3、如何利用 v-for 和 ref 获取一组数组或者dom 节点
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8" />
<meta http-equiv="X-UA-Compatible" content="IE=edge" />
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
<title>Document</title>
<script src="./vue.js"></script>
</head>
<body>
<div id="app">
<div class="box1" ref="box">这个是box1</div>
<kky ref="box2"></kky>
<button @click="fn1">点击获取box1</button>
<button @click="fn2">点击获取</button>
</div>
<script>
let kky = {
data() {
return {
money: 200,
};
},
template: `
<div>
kky组件 {{ money }}
</div>
`,
methods: {
do() {
console.log("do");
},
},
};
let app = new Vue({
el: "#app",
data: {},
components: {
kky,
},
methods: {
fn1() {
// 在 vue 框架里 如何获取dom元素
let r1 = document.getElementsByClassName("box1")[0];
// 第二种方式
let r2 = this.$refs.box;
// console.log("r1:", r1);
},
fn2() {
let r3 = this.$refs.box2;
console.log("r3:", r3.money);
r3.do();
},
},
});
</script>
</body>
</html>
版权声明:本文为weixin_59519449原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。