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进行安装。导入和使用它可以正常工作,但是当我运行我的项目时出现错误:
无法安装组件:模板或渲染功能未定义。关于此错误找到的所有其他帖子都无法解决我的问题,因为他们都没有尝试导出多个组件。
当我将它们发布到两个不同的项目中时,这两个组件完全可以按预期工作。
我在这里想念什么?提前致谢!
您不需要使用该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
| 归档时间: |
|
| 查看次数: |
1250 次 |
| 最近记录: |