当前位置: 代码网 > it编程>前端脚本>Vue.js > VUE中watch的详细使用教程(推荐!)

VUE中watch的详细使用教程(推荐!)

2024年08月08日 Vue.js 我要评论
这篇文章主要给大家介绍了关于VUE中watch的详细使用教程,watch是vue实例的一个属性,主要用来监听数据的变化,并做出一些操作,需要的朋友可以参考下

1、watch是什么?

watch:是vue中常用的侦听器(监听器),用来监听数据的变化

2、watch的使用方式如下

watch: {

        这里写你在data中定义的变量名或别处方法名: {

                handler(数据改变后新的值, 数据改变之前旧的值) {

                                这里写你拿到变化值后的逻辑

                        }

                }

        }

3、watch监听简单案例(监听一个)

<template>
  <div>
    <div>
      <input type="text" v-model="something">
    </div>
  </div>
</template>
<script>
  export default {
    name: "aboutview",
    components: {},
    data() {
      return {
         something: ""
      }
    },
    watch: {
        //方法1
       "something"(newval, oldval) {
          console.log(`新值:${newval}`);
          console.log(`旧值:${oldval}`);
          console.log("hellow  world");
      }
        //方法2
        "something": {
            handler(newval, oldval) {
              console.log(`新的值: ${newval}`);
              console.log(`旧的值: ${oldval}`);
              console.log("hellow  world");
            }
          }
        }
      }
</script>

在输入框中输入1、4   效果图如下:

4、watch监听复杂单一案例(例:监听对象中的某一项)

<template>
  <div>
    <div>
      <input type="text" v-model="obj.something">
    </div>
  </div>
</template>
<script>
  export default {
    name: "aboutview",
    components: {},
    data() {
      return {
         obj: {
           something: ""
        }
      }
    },
    watch: {
        "obj.something": {
            handler(newval, oldval) {
              console.log(`新的值: ${newval}`);
              console.log(`旧的值: ${oldval}`);
              console.log("hellow  world");
            }
          }
        }
      }
</script>

 在输入框中输入4、5   效果图如下:

5、watch中immediate的用法和作用

1、作用:immediate页面进来就会立即执行,值需要设为true

2、用法如下方代码所示:

<template>
  <div>
    <div>
      <input type="text" v-model="obj.something">
    </div>
  </div>
</template>
<script>
  export default {
    name: "aboutview",
    components: {},
    data() {
      return {
         obj: {
           something: ""
        }
      }
    },
    watch: {
        "obj.something": {
            handler(newval, oldval) {
              console.log(`新的值: ${newval}`);
              console.log(`旧的值: ${oldval}`);
              console.log("hellow  world");
            },
            immediate:true
          }
        }
      }
</script>

进来页面后立即加载,效果图如下:

6、watch中deep 深度监听的用法和作用

1、作用:deep 用来监听data中的对象,值需要设为true

2、用法如下方代码所示:

<template>
  <div>
    <div>
      <input type="text" v-model="obj.something">
    </div>
  </div>
</template>
<script>
  export default {
    name: "aboutview",
    components: {},
    data() {
      return {
         obj: {
           something: ""
        }
      }
    },
    watch: {
        "obj": {
            handler(newval, oldval) {
              console.log(`新的值: ${newval}`);
              console.log(`旧的值: ${oldval}`);
              console.log("hellow  world");
            },
            deep:true
          }
        }
      }
</script>

注意:

1、console.log(`新的值: ${newval}`); 这种打印出来的是对象的类型,如下图:

 2、console.log(newval);这种打印出来的是对象本身,如下图:

总结 

到此这篇关于vue中watch的详细使用教程的文章就介绍到这了,更多相关vue watch使用教程内容请搜索代码网以前的文章或继续浏览下面的相关文章希望大家以后多多支持代码网!

(0)

相关文章:

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论

验证码:
Copyright © 2017-2025  代码网 保留所有权利. 粤ICP备2024248653号
站长QQ:2386932994 | 联系邮箱:2386932994@qq.com