6

我有一个 Vue 2.6 项目,我想在我的项目中使用 es2020 特性,如可选链接,但我无法让它在我的项目中工作。我收到以下错误。

> vue-cli-service serve

 INFO  Starting development server...
98% after emitting CopyPlugin

 ERROR  Failed to compile with 1 error                                                                                                           12:59:10

 error  in ./src/components/list/columns/lastUpdate.vue?vue&type=script&lang=js&

Module parse failed: Unexpected token (15:20)
File was processed with these loaders:
 * ./node_modules/cache-loader/dist/cjs.js
 * ./node_modules/babel-loader/lib/index.js
 * ./node_modules/cache-loader/dist/cjs.js
 * ./node_modules/vue-loader/lib/index.js
You may need an additional loader to handle the result of these loaders.
|       if (!this.data.ObjInst || !this.data.ObjInst.Last_Update) return '';
| 
>       if (this.data?.ObjInst) {
|         console.log("Hello");
|       }

 @ ./src/components/list/columns/lastUpdate.vue?vue&type=script&lang=js& 1:0-349 1:365-368 1:370-716 1:370-716
 .
 .
 .
 .
 .
 @ ./node_modules/cache-loader/dist/cjs.js??ref--12-0!./node_modules/babel-loader/lib!./node_modules/cache-loader/dist/cjs.js??ref--0-0!./node_modules/vue-loader/lib??vue-loader-options!./src/App.vue?vue&type=script&lang=js&
 @ ./src/App.vue?vue&type=script&lang=js&
 @ ./src/App.vue
 @ ./src/main.js
 @ multi (webpack)-dev-server/client?http://192.168.0.21:8080/sockjs-node (webpack)/hot/dev-server.js ./src/main.js

我已经安装了 babel 插件,但我得到了同样的错误。

npm install --save-dev @babel/plugin-proposal-optional-chaining

我一直在谷歌搜索,但我没有找到任何关于它的信息。

这些是我项目的依赖项

{
...
  "dependencies": {
    "core-js": "^2.6.11",
    "jwt-decode": "^2.2.0",
    "vue": "^2.6.12",
    "vue-i18n": "^8.24.2",
    "vue-multiselect": "^2.1.6",
    "vue2-admin-lte": "^0.4.3",
    "vue2-daterange-picker": "^0.6.1"
  },
  "devDependencies": {
    "@kazupon/vue-i18n-loader": "^0.3.0",
    "@vue/cli-plugin-babel": "^3.12.1",
    "@vue/cli-plugin-eslint": "^3.12.1",
    "@vue/cli-service": "^3.12.1",
    "babel-eslint": "^10.1.0",
    "eslint": "^5.16.0",
    "eslint-plugin-vue": "^5.0.0",
    "vue-cli-plugin-i18n": "^0.6.1",
    "vue-template-compiler": "^2.6.12"
  },
  "eslintConfig": {
    "root": true,
    "env": {
      "node": true
    },
    "extends": [
      "plugin:vue/essential",
      "eslint:recommended"
    ],
    "rules": {},
    "parserOptions": {
      "parser": "babel-eslint"
    }
  }
...
}

请帮我!

4

4 回答 4

0

据我了解,这是因为 Vue 项目的标准设置使用 Babel/Webpack 将代码转换为可以在浏览器中运行的东西(即 Vue 模板来呈现函数),并为新功能添加 polyfill 以实现向后兼容性。Vue 2 使用 Babel 6/Webpack 4,他们在 Vue 3 中迁移到 Babel 7/Webpack 5。

@vue/cli目前有一个测试版,用于管理对 Babel/Webpack 的升级,但它可能需要你重写一些配置。

于 2021-05-03T13:41:40.023 回答
0

正如@awston 提到的,这是因为 Webpack。

Optional-chaining 不久前进入 Acorn,并且 Webpack(依赖于它)仅从版本开始支持它。5(在 @vue/cli 版本 5 中可用,仍处于测试阶段)。

你可以在 webpack 版本中使用它。4 也是如此,但要准备好在你的项目中调整一些 babel(这并不难!)

您应该在 github 中进一步阅读此问题,准确分配您的问题

于 2021-05-03T14:00:37.970 回答
0

@Loop,在 vue.config.js 文件中添加以下 webpack 对象(chainedWebpack):

module.exports = {  
 chainWebpack: config => {
  config.module
  .rule('vue')
  .test(/\.vue$/)
  .use('vue-loader')
    .loader('vue-loader')
    .tap(options => {
      // modify the options...
      return options
    })
  .end()
  .use('vue-style-loader')
  .loader('vue-style-loader')
  .end()
 }
}

请让我知道它是否适合您。

于 2021-06-26T13:04:05.273 回答
-1

我不认为你可以实现这一点,除非你自己实现它。ES2020 中提供了这样的可选链接功能Vue 3,但不提供Vue 2.x

更多信息可以在这里找到

于 2021-04-27T11:31:21.883 回答