V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
wxsm
V2EX  ›  Vue.js

一个奇怪的 bug(Vue 项目与插件获取了不一样的 Vue 构建版本)

  •  
  •   wxsm ·
    wxsms · 2017-12-04 10:42:34 +08:00 · 2088 次点击
    这是一个创建于 2576 天前的主题,其中的信息可能已经有所发展或是发生改变。

    (虽然我是在自己的项目中第一次发现这个问题,但是后来测试了 element-ui 与 iview 其实都存在相同的情况,所以这不是我自己的 lib 的问题)

    我有一个使用 webpack 导出的 lib 项目:

    // webpack config
    {
      ...
      externals: {
        vue: {
          root: 'Vue',
          commonjs: 'vue',
          commonjs2: 'vue',
          amd: 'vue'
        }
      },
      output: {
        ...
        libraryTarget: 'umd'
      },
      ...
    }
    

    然后我想要在 Vue.js 的官方 browserify template 项目中使用它:

    // main.js
    import Vue from 'vue'
    import * as mylib from 'mylib'
    
    Vue.use(mylib)
    

    然后问题就来了。项目本体使用的是 vue.common.js 构建,而 lib 却使用了 vue.runtime.common.js 构建。

    更甚者,无论我怎么更改项目本体的构建依赖,插件将始终使用 vue.runtime.common.js 构建。

    如果我同时在项目本体中与 lib 中执行 console.log(Vue.version, typeof Vue.compile),将得到如下的结果:

    Image

    可以看到控制台中同时出现了 vue.common.jsvue.runtime.common.js 的输出,项目本体中 typeof Vue.compilefunction, 但是在 lib 中为 undefined.

    为什么会这样?我要如何保证 lib 能够跟项目本体获取到一样的 Vue 构建?

    目前尚无回复
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   1593 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 23ms · UTC 16:45 · PVG 00:45 · LAX 08:45 · JFK 11:45
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.