使用Webpack将一个项目中的多个Vuejs组件发布到npm

Leo*_*ert 3 node.js npm vue.js vue-component vuejs2

我试图将包含两个或多个Vue组件的项目发布到npm,以便我可以像这样导入,注册和使用这两个组件:

import Component1 from 'npm-package'
import Component2 from 'npm-package'
Run Code Online (Sandbox Code Playgroud)

这是我的webpack文件:

const webpack = require('webpack');
const merge = require('webpack-merge');
const path = require('path');

var config = {
  output: {
    path: path.resolve(__dirname + '/dist/'),
  },
  module: {
    loaders: [
      {
        test: /\.js$/,
        loader: 'babel',
        include: __dirname,
        exclude: /node_modules/
      },
      {
        test: /\.vue$/,
        loader: 'vue'
      },
      {
        test: /\.css$/,
        loader: 'style!less!css'
      }
    ]
  },
  externals: {
    moment: 'moment'
  },
  plugins: [
    new webpack.optimize.UglifyJsPlugin( {
      minimize : true,
      sourceMap : false,
      mangle: true,
      compress: {
        warnings: false
      }
    } )
  ]
};


module.exports = [
  merge(config, {
    entry: path.resolve(__dirname + '/src/plugin.js'),
    output: {
      filename: 'vue-project.min.js',
      libraryTarget: 'window',
      library: 'VueProject',
    }
  }),
  merge(config, {
    entry: path.resolve(__dirname + '/src/index.js'),
    output: {
      filename: 'vue-project.js',
      libraryTarget: 'umd',
      library: 'vue-project',
      umdNamedDefine: true
    },
    resolve: {
      extensions: ['', '.js', '.vue'],
      alias: {
        'src': path.resolve(__dirname, '../src'),
        'components': path.resolve(__dirname, '../src/components')
      }
    }
  })
];
Run Code Online (Sandbox Code Playgroud)

这是我正在用作构建过程入口点的index.js文件

import Component1 from './components/folder1/Component1.vue'
import Component1 from './components/folder2/Component2.vue'

export default {
  components: {
    Component1,
    Component2
  }
}
Run Code Online (Sandbox Code Playgroud)

使用npm run build的构建过程工作正常,我可以将项目发布到npm并使用npm install进行安装。导入和使用它可以正常工作,但是当我运行我的项目时出现错误:

无法安装组件:模板或渲染功能未定义。关于此错误找到的所有其他帖子都无法解决我的问题,因为他们都没有尝试导出多个组件。

当我将它们发布到两个不同的项目中时,这两个组件完全可以按预期工作。

我在这里想念什么?提前致谢!

cra*_*g_h 5

您不需要使用该components属性进行导出,只需执行以下操作:

export {
    Component1,
    Component2
}
Run Code Online (Sandbox Code Playgroud)

然后,您将执行以下操作:

import {Component1} from 'npm-package';
import {Component2} from 'npm-package';
Run Code Online (Sandbox Code Playgroud)

要么

import {Component1, Component2} from 'npm-package';
Run Code Online (Sandbox Code Playgroud)

请参阅:https//developer.mozilla.org/zh-CN/docs/web/javascript/reference/statements/export