webpack vue 错误

标签 webpack babeljs vue.js

我已经全局安装了 webpack,并在本地安装了 vue 和 loader,并尝试在全局安装它们。当我运行 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';

main.js

import Vue from 'vue'
import App from './app.vue'

new Vue({
    el: 'body',
    components: { App }
})

配置

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'
        }
    }
}

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"
    }
}

不确定我错过了什么

最佳答案

您缺少 es-2015 转换。

在 6.x 之前,Babel 默认启用某些转换。然而,Babel 6.x 并未启用任何转换。您需要明确告诉它要运行哪些转换。最简单的方法是使用预设,例如 ES2015 预设。您可以使用以下命令安装它

npm install babel-preset-es2015 --save-dev

然后设置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'
        }
    }
}

引用:

https://babeljs.io/docs/setup/#webpack

关于webpack vue 错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35387991/

相关文章:

typescript - @Watch装饰器未激活

vue.js - 仅在满足条件时才使用插槽的回退内容

reactjs - 弹出构建组件库后create-react-app的配置

reactjs - 在包/组件的单一仓库中运行 Babel

typescript - Jest : Failed to parse the TypeScript config file

javascript - Eslint: no-duplicates 解决错误:无法加载解析器 "node"

webpack - Babel为什么不转换我的类(class)属性?

java - Angular2 在使用 XMLHttpRequest 发帖时正在刷新页面

typescript - 使用 TypeScript 的 Webpack - 当定位到 ES6 时,未定义导入键

javascript - 如何在 ES2015 模块中使用全局变量