vue 中 ref 的作用?

获取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版权协议,转载请附上原文出处链接和本声明。