javascript - vue2.0 在mounted时不能获取到$route.query的值?
PHP中文网
PHP中文网 2017-04-11 11:03:37
[JavaScript讨论组]
mounted() {
    //直接打印不到
    this.setUserInfo();
    
    //加一定的延时就可以打印出来
    let _this = this;
    setTimeout(function() {
        _this.setUserInfo();
    }, 100)
    
},

methods: {
    //将url传递过来的参数存入LocalStorage
    setUserInfo: function() {
        let userInfo = this.$route.query;
        console.log(userInfo)
    }
},

如上,直接在mounted时打印不到this.$route.query的值。加一个延时就好了。是什么原因呢?

PHP中文网
PHP中文网

认证高级PHP讲师

全部回复(4)
PHP中文网

这个你可以看看vue的生命周期。

mounted    模版编译、挂载之后(不保证组件已在document中)

所以可能出现你的情况,组件及其上的方法没在dom中,加个延时,渲染好了,然后你的打印就有东西

黄舟

那就beforeMount

黄舟

写到 created() 里?

巴扎黑

bold

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号