【Vue 快速入门系列】通过天气案例快速掌握监视属性

简介: 【Vue 快速入门系列】通过天气案例快速掌握监视属性

前言


前面一篇博客提到了计算属性的使用,本篇博客将会使用计算属性实现一下简单的天气案例,然后引出监视属性,并学习深度监视,使用监视属性实现上一篇博客中的姓名案例,总的来说呢计算属性可以实现的东西,监视属性同样可以实现。反过来监视属性可以实现的东西计算属性不一定可以实现。


先来看一下案例的效果(通过点击按钮,切换dom元素内展示的文字)


a3a080fb848f45938a64418c415d949f.gif


使用计算属性实现天气案例


<!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 type="text/javascript" src="../js/vue.js"></script>
</head>
<body>
    <div id="demo">
        <h1>今天天气状态为{{cls}}!</好>
        <br>
        <button @click="trans">点击切换天气</button>
    </div>
</body>
<script>
    let vm=new Vue({
        el:"#demo",
        data:{
            tag:true
        },
        methods:{
            trans(){
                this.tag=(!this.tag)
            }
        },
        computed:{
            cls(){
                return this.tag?"晴天":"阴天"
            }
        }
    })
</script>
</html>


使用监视属性实现天气案例


监视属性有如下特征:


监视属性使用关键字是watch,每一个监视属性配置中都有一个handler在监视的属性被改变时而进行回调
监视属性必须存在才可以进行监视
监视属性有两种写法:
    new Vue的时候进行watch配置
    通过对vue对象进行添加(使用$watch(监视的属性名,监视配置))


<!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 type="text/javascript" src="../js/vue.js"></script>
    <!-- 
        众所周知,在进行计算属性的时候当数据刚开始加载的时候数据会更新一下
        当计算属性时,数据用到的数据有所改变的时候还会进行一下属性的更新。
        计算属性可以在刚开始不用存在,但是可以在模板中使用
    -->
</head>
<body>
    <div id="demo">
        <h1>今天的天气是{{info}}!</h1>
        <br>
        <button @click="temp">点我进行天气切换</button>
    </div>
</body>
<script>
    // 第一种方法:直接对vue对象进行配置
    /*let vm=new Vue({
        el:"#demo",
        data:{
            tag:true,
        },
        methods: {
            temp(){
                this.tag=!this.tag
            }
        },
        computed:{
            info(){
                return this.tag?"晴天":"阴天"
            }
        },
        watch:{
            tag:{
                immediate:true,//在页面刚开始加载的时候调用一下回调函数
                handler(newv,oldv){
                    console.log("监视的值改变了(新旧值分别为:)",newv,oldv)
                }
            }
        }
    })
    */
    //第二种方法:先创建对象然后进行动态配置
    let vm=new Vue({
        el:"#demo",
        data:{
            tag:true,
        },
        methods: {
            temp(){
                this.tag=!this.tag
            }
        },
        computed:{
            info(){
                return this.tag?"晴天":"阴天"
            }
        }
    })
    vm.$watch("tag",{
        immediate:true,
        handler(newv,oldv){
            console.log("监视的值改变了(新旧值分别为:)",newv,oldv)
        }
    })
</script>
</html>


深度监视


什么是深度监视:
    如果监视某个属性,我们可以采取用.拼接的形式,逐层访问到某一个属性
    如果有一种需求就是检测某一数据节点下所有的子数据,在子数据有所改变的时候提示该节点存在数据改变
    并且该节点的子节点数据量很多的话,一个一个写显得有些不现实,深度检测就是为了应对这些问题
需要手动开启深度监视的原因是:Vue对象的watch默认不检测对象内部值的改变
tips:
    Vue对象时刻检测对象内部值的变化,Vue提供的watch默认不可以
    (watch不加deep:true检测不到子节点的数据变化,Vue对象可以检测到)
深度监视语法:
    在被监视属性的配置中加入deep:true


<!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 type="text/javascript" src="../js/vue.js"></script>
</head>
<body>
    <div id="demo">
        <!-- 检测某节点的子节点 -->
        <h1>深度监视测试-----深度检测</h1>
        <hr>
        <button @click="number.a++">点我a++</button>
        <button @click="number.b++">点我b++</button>
        <!-- 如果不加深度监视只有这种情况会提示number改变了 -->
        <button @click="number={a:888,b:888}">点我替换a与b</button>
        <h1>深度监视测试-----精准检测</h1>
        <hr>
        <!-- 这里的t3在test对象内的t1内的t2对象中 -->
        <button @click="test.t1.t2.t3++">点我t3++</button>
    </div>
</body>
<script>
    let vm=new Vue({
        el:"#demo",
        data:{
            number:{
                a:0,
                b:0
            },
            test:{
                t1:{
                    t2:{
                        t3:0
                    }
                }
            }
        },
        watch:{
            number:{
                deep:true,
                handler(){
                    console.log("number数值改变了!")
                }
            },
            'test.t1.t2.t3':{
                handler(){
                    console.log("t3数据改变了!")
                }
            }
        }
    })
</script>
</html>


监视属性的简写方式


<!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 type="text/javascript" src="../js/vue.js"></script>
</head>
<body>
    <div id="demo">
        <h1>监视属性简写</h1>
        <h2>今天的天气是{{info}}</h2>
        <button @click="alertTag">点我切换天气</button>
    </div>    
</body>
<script>
    let vm=new Vue({
        el:"#demo",
        data:{
            tag:true
        },
        methods: {
            alertTag() {
                this.tag=!this.tag
            }
        },
        computed:{
            info(){
                return this.tag?"晴天!":"阴天!"
            }
        },
        //写法如此,可以直接用被监视的属性名作为函数名,然后操作。这里的参数如果是一个就是新值,如果是两个就与原来一样。
        watch:{
            tag(nv){
                immedite:true
                console.log("监视的tag发生了变化,新的值为:"+nv)
            }
        }
    })
    // vm.$watch(tag,(newvalue)=>{
    //     console.log("数据发生了变化!新的值为:"+newvalue)
    // })
</script>
</html>


使用监视属性实现姓名案例


在本案例中监视属性不可以是最后生成的属性,监视属性的工作原理就是被监视属性一旦发生改变就执行回调,如果监视最终的属性,那么会陷入一直回调,就会导致程序出错。只能监视输入框内的属性,当输入框内的属性改变时直接修改最终需要展示的结果。


<!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 type="text/javascript" src="../js/vue.js"></script>
</head>
<body>
    <div id="demo">
        <h1>使用watch实现姓名案例</h1>
        姓:<input v-model="firstName"><br>
        名:<input v-model="lastName"><br>
        姓名:<div>{{allName}}</div>
    </div>
</body>
<script>
    let vm=new Vue({
        el:"#demo",
        data:{
            firstName:"张",
            lastName:"三",
            allName:"张-三"
        },
        watch:{
            //常规写法
            /*firstName:{
                handler(nv){
                    this.allName=nv+"-"+this.lastName
                }
            },*/
            //定时一秒后才展示修改结果
            firstName(nv){
                setTimeout(()=>{
                    this.allName=nv+"-"+this.lastName
                },1000)
            },
            lastName:{
                handler(nv){
                    this.allName=this.firstName+"-"+nv
                }
            }
        }
    })
</script>
</html>


今天的分享就到此结束吧!

相关文章
|
1月前
|
存储 缓存 JavaScript
如何在大型 Vue 应用中有效地管理计算属性和侦听器
在大型 Vue 应用中,合理管理计算属性和侦听器是优化性能和维护性的关键。本文介绍了如何通过模块化、状态管理和避免冗余计算等方法,有效提升应用的响应性和可维护性。
|
2月前
|
监控 JavaScript 开发者
在 Vue 中,子组件为何不可以修改父组件传递的 Prop,如果修改了,Vue 是如何监控到属性的修改并给出警告的
在 Vue 中,子组件不能直接修改父组件传递的 Prop,以确保数据流的单向性和可预测性。如果子组件尝试修改 Prop,Vue 会通过响应式系统检测到这一变化,并在控制台发出警告,提示开发者避免这种操作。
|
2月前
|
JavaScript 前端开发 开发者
VUE学习一:初识VUE、指令、动态绑定、计算属性
这篇文章主要介绍了Vue.js的基础知识,包括初识Vue、指令如v-for、v-on的使用、动态属性绑定(v-bind)、计算属性等概念与实践示例。
66 1
|
2月前
|
缓存 JavaScript Serverless
vue中computed计算属性、watch侦听器、methods方法的区别以及用法
vue中computed计算属性、watch侦听器、methods方法的区别以及用法
149 0
|
1月前
|
JavaScript API 开发者
Vue是如何进行组件化的
Vue是如何进行组件化的
|
7天前
|
JavaScript 关系型数据库 MySQL
基于VUE的校园二手交易平台系统设计与实现毕业设计论文模板
基于Vue的校园二手交易平台是一款专为校园用户设计的在线交易系统,提供简洁高效、安全可靠的二手商品买卖环境。平台利用Vue框架的响应式数据绑定和组件化特性,实现用户友好的界面,方便商品浏览、发布与管理。该系统采用Node.js、MySQL及B/S架构,确保稳定性和多功能模块设计,涵盖管理员和用户功能模块,促进物品循环使用,降低开销,提升环保意识,助力绿色校园文化建设。
|
1月前
|
JavaScript 前端开发 开发者
vue学习第一章
欢迎来到我的博客!我是瑞雨溪,一名热爱前端的大一学生,专注于JavaScript与Vue,正向全栈进发。博客分享Vue学习心得、命令式与声明式编程对比、列表展示及计数器案例等。关注我,持续更新中!🎉🎉🎉
41 1
vue学习第一章
|
1月前
|
JavaScript 前端开发 索引
vue学习第三章
欢迎来到瑞雨溪的博客,一名热爱JavaScript与Vue的大一学生。本文介绍了Vue中的v-bind指令,包括基本使用、动态绑定class及style等,希望能为你的前端学习之路提供帮助。持续关注,更多精彩内容即将呈现!🎉🎉🎉
30 1
|
1月前
|
缓存 JavaScript 前端开发
vue学习第四章
欢迎来到我的博客!我是瑞雨溪,一名热爱JavaScript与Vue的大一学生。本文介绍了Vue中计算属性的基本与复杂使用、setter/getter、与methods的对比及与侦听器的总结。如果你觉得有用,请关注我,将持续更新更多优质内容!🎉🎉🎉
38 1
vue学习第四章
|
1月前
|
JavaScript 前端开发 算法
vue学习第7章(循环)
欢迎来到瑞雨溪的博客,一名热爱JavaScript和Vue的大一学生。本文介绍了Vue中的v-for指令,包括遍历数组和对象、使用key以及数组的响应式方法等内容,并附有综合练习实例。关注我,将持续更新更多优质文章!🎉🎉🎉
25 1
vue学习第7章(循环)

热门文章

最新文章