Thi*_*ngs 1 webpack vue.js babeljs
我在全球安装了webpack,并在本地安装了vue和loaders,并尝试在全球范围内安装它们.我运行webpack时不断收到此错误
Module parse failed: /Users/joebob/Development/vue-test/node_modules/babel-loader/index.js!/Users/joebob/Development/vue-test/src/main.js Line 1: Unexpected token
You may need an appropriate loader to handle this file type.
| import Vue from 'vue';
Run Code Online (Sandbox Code Playgroud)
main.js
import Vue from 'vue'
import App from './app.vue'
new Vue({
el: 'body',
components: { App }
})
Run Code Online (Sandbox Code Playgroud)
配置
module.exports = {
entry: './src/main.js',
output: {
path: './dist',
publicPath: 'dist/',
filename: 'build.js'
},
module: {
loaders: [
{
test: /\.js$/,
loader: 'babel',
exclude: /node_modules/
},
{
test: /\.vue$/,
loader: 'vue'
}
]
},
vue: {
loaders: {
js: 'babel'
}
}
}
Run Code Online (Sandbox Code Playgroud)
的package.json
{
"name": "vue-test",
"version": "1.0.0",
"dependencies": {
"vue": "^1.0.16"
},
"devDependencies": {
"babel-core": "^6.1.2",
"babel-loader": "^6.1.0",
"babel-plugin-transform-runtime": "^6.1.2",
"babel-preset-es2015": "^6.1.2",
"babel-preset-stage-0": "^6.1.2",
"babel-runtime": "^5.8.0",
"webpack": "^1.12.2",
"css-loader": "^0.23.0",
"style-loader": "^0.13.0",
"vue-loader": "^7.3.0",
"vue-html-loader": "^1.0.0",
"vue-hot-reload-api": "^1.2.0"
}
}
Run Code Online (Sandbox Code Playgroud)
不知道我错过了什么
你错过了es-2015转型.
在6.x之前,Babel默认启用了某些转换.但是,Babel 6.x不附带任何启用的转换.您需要明确告诉它要运行什么转换.最简单的方法是使用预设,例如ES2015预设.你可以安装它
npm install babel-preset-es2015 --save-dev
Run Code Online (Sandbox Code Playgroud)
然后设置babel-loader使用它:
配置:
module.exports = {
entry: './src/main.js',
output: {
path: './dist',
publicPath: 'dist/',
filename: 'build.js'
},
module: {
loaders: [
{
test: /\.js$/,
loader: 'babel-loader',
exclude: /node_modules/
query: {
presets: ['es2015']
}
},
{
test: /\.vue$/,
loader: 'vue'
}
]
},
vue: {
loaders: {
js: 'babel'
}
}
}
Run Code Online (Sandbox Code Playgroud)
参考:
https://babeljs.io/docs/setup/#webpack
| 归档时间: |
|
| 查看次数: |
4398 次 |
| 最近记录: |