zoukankan      html  css  js  c++  java
  • vue单文件组件无法获取$refs的问题

    原文https://blog.phyer.cn/article/8369

    记录一下学习webpack+vue碰到的一个大坑,踩这个坑是我才疏学浅的表现,特此引以为戒。因为该坑实在是太坑了!

    代码

    header.html

    <body>
    <div id="popup-wrap">
    <popup ref="popup"></popup>
    </div>
    </body>

    header.js

    import popup from '../../components/popup/popup.vue'
    import './header.scss'
    
    let header_vue;
    $(function () {
    header_vue = new Vue({
    el: '#popup-wrap',
    data: {
    },
    mounted: {
    // 输出为{popup: VueComponent}
    console.log(this.$refs);
    }
    components: {popup},
    methods: {
    pop_data: function () {
    // 输出为{}
    console.log(this.$refs);
    }
    }
    });
    });
    export {header_vue}

    other.js

    import {header_vue} from "../header/header";
    
    $(function () {
    header_vue.pop_data()
    });

     `popup.vue`是一个普通的弹窗组件。我在`header.js`中引入该组件,并实例化一个`header_vue`使用了`popup`组件,然后在`other.js`中引入`header_vue`试图使用`pop_data`函数,该函数仅输出`header_vue`的`$refs`,经测试,该函数输出为一个空的对象,但是`mounted钩子`正常输出。

    我就很纳闷,为啥`mounted`输出正常,函数调用就成空的了呢,Vue也已经挂载完成了啊。

    resolve

    一番气急败坏的debug后,在`header.js`的`$(function())`加上了一句`console.log('ok')`,结果浏览器输出了俩ok。短时间大脑的高速运转后,我发现了问题的所在:

     webpack打包了两遍`header.js`!

    所以解决的办法就是把`header_vue = new Vue()`改成`window.header_vue = new Vue()`。别处直接用就行了。

    尾话

    目前没搞清楚具体的bug出现原因,正常使用webpack多次引入同一个export也没有出现过此问题。但是肯定是我没学明白,有大牛知道的话麻烦解答解答。

  • 相关阅读:
    PHP常量
    jquery中的几种常用总结
    jquery中的ajax
    常用的jquery一些总结
    js验证手机号邮箱号用户名
    PHP优化杂烩
    一个php开发的用于路由器的小功能
    HTML <form>
    window.open
    try&catch
  • 原文地址:https://www.cnblogs.com/yunyuyuan/p/13185279.html
Copyright © 2011-2022 走看看