Vue-watch监听

文章通过一个Vue实例展示了如何使用v-model绑定数据,并在数据变化时进行浅监听和深度监听。深度监听允许对嵌套数据对象的变更进行跟踪,而不仅仅是顶层属性的变化。在示例中,msg的改变触发了浅监听,检查手机号格式,而arr则应用了深度监听,每次数组内容变化时都会触发处理函数。

        Vue的监听有前监听和深度监听,最简单来说的区别是深度监听可以监听数据变化,每当监听的数据变化时便会调用。

<!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>深浅监听</title>
    <script src="vue.js"></script>
</head>
<style>
    .colors{
        color: rgb(23, 207, 26);
    }
    .error{
        color: rgb(201, 31, 31);
    }
</style>
<body>
    <div class="app"> 
        <div >
            <input type="text" v-model="msg" placeholder="请输入手机号">
            <div :class="[xxx==='手机号输入正确' ? 'colors':'error']"> {{xxx}}</div>
           
        </div>
        <div>
            <input type="text" v-model="arr" >
            {{arr}}
        </div>
    </div>
</body>
</html>
<script>
    new Vue({
        el:".app",
        data:{
            xxx:'',
            msg:null,
            arr:[1,2,3,4]
        },
        watch:{
            //浅监听
            msg(newValue,oldValue){//newValue修改的数据,oldValuex旧数据
                const re=/^1+[13578][0-9]{9}$/;
                if(re.test(newValue)){
                    this.xxx="手机号输入正确"
                }
                else{
                    this.xxx='手机号输入不正确'
                }
                console.log(newValue,":newValue",oldValue,":oldValue")
            },
            arr:{
                //handler深度监听
                handler(newvalue){
                    console.log(newvalue,"深度监听")//数值改变进行的操作
                },
                //immediate不管是否改动都会执行一次
                immediate:true
            }
        }
    })
</script>

Vue.js 应用中,使用 `vue-router` 监听 URL 的变化主要依赖于其内置的响应式机制和导航守卫功能。通过以下步骤可以实现对地址栏变化的监听: ### 1. 初始化 vue-router 并绑定路由规则 首先,在项目中需要正确初始化 `vue-router` 并配置路由规则。通常在 `src/router/index.js` 中定义路由表,并将其注入到 Vue 实例中: ```javascript import Vue from 'vue' import Router from 'vue-router' import HelloWorld from '@/components/HelloWorld' Vue.use(Router) export default new Router({ routes: [ { path: '/', name: 'HelloWorld', component: HelloWorld } ] }) ``` ### 2. 使用 $route 对象监听 URL 变化 在组件内部,可以通过 `this.$route` 访问当前的路由信息。由于 `$route` 是一个响应式对象,当 URL 发生变化时,它会自动更新。因此,可以在组件中使用 `watch` 来监听 `$route` 的变化: ```javascript export default { watch: { '$route' (to, from) { // 在这里处理 URL 变化逻辑 console.log('路由从', from.path, '变到', to.path) } } } ``` ### 3. 使用导航守卫进行全局或局部监听 除了在组件内部监听 `$route`,还可以使用导航守卫来捕获全局或局部的路由变化事件。 #### 全局前置守卫(beforeEach) 在路由实例上使用 `beforeEach` 方法可以监听所有路由的变化: ```javascript router.beforeEach((to, from, next) => { // 在这里执行路由切换前的操作 console.log('即将跳转到:', to.path) next() }) ``` #### 组件内守卫 在特定组件中也可以定义 `beforeRouteEnter`、`beforeRouteUpdate` 和 `beforeRouteLeave` 等钩子函数来监听该组件相关的路由变化: ```javascript export default { beforeRouteEnter(to, from, next) { next(vm => { console.log('进入路由:', to.path) }) }, beforeRouteUpdate(to, from, next) { console.log('更新路由:', to.path) next() }, beforeRouteLeave(to, from, next) { console.log('离开路由:', to.path) next() } } ``` ### 4. 使用 router.app.$on('hook:activated') 进行组件激活监听 如果组件是通过 `<keep-alive>` 缓存的,还可以监听 `activated` 生命周期钩子来响应 URL 的变化: ```javascript created() { this.routerHook = () => { console.log('URL 变化了') } this.$on('hook:activated', this.routerHook) }, beforeDestroy() { this.$off('hook:activated', this.routerHook) } ``` ### 5. 利用 defineReactive 实现数据响应式更新 在底层实现中,`vue-router` 通过调用 Vue 工具类方法 `defineReactive` 来确保 `router` 的变化能够触发页面的响应式更新。这一过程通常由框架自动完成,无需手动干预[^1]。 ### 总结 通过上述步骤,可以在 Vue.js 应用中有效地使用 `vue-router` 监听 URL 的变化。无论是通过 `$route` 的响应式特性,还是利用导航守卫提供的强大功能,都可以灵活地控制路由行为并做出相应的业务处理。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值