node.js - 即使在 Webstorm 2018.3 中进行 Babel 配置后,Spread Operator 也会抛出 SyntaxError

标签 node.js webstorm babeljs

网络 Storm /操作系统

Webstorm 2018.3/Windows 10

Node/NPM

v8.0.0/6.4.1

遵循的步骤

  1. JetBrains ECMAScript6 in Webstorm Babel FileWatcher

    我通过步骤添加了 Babel

  2. 对于本地存储库,我安装了npm i --save-dev @babel/cli @babel/core @babel/preset-env @babel/plugin-object-propose-rest-spread

  3. 在根文件夹中添加了.babelrc,内容如下:

     {
       "presets": ["@babel/preset-env"],
       "plugins": ["@babel/plugin-proposal-object-rest-spread"]
     }
    
  4. npm start 配置了运行配置,因为我的 package.json 中有 "start": nodemon app.js .

应用

我使用 mongoose 来存储和从 MongoDB 获取信息,并使用 GraphQL 提供查询/突变的端点

这是我的代码中的一个变异(函数):

 createEvent: (args) => {
            const event = new Event({
               title: args.eventInput.title,
               description: args.eventInput.description,
               price: +args.eventInput.price,
               date: new Date(args.eventInput.date)
            });
            return event
                .save()
                .then(result => {
                    console.log(result);
                    return { ...result._doc };
                })
                .catch(err => {
                    console.log(err);
                    throw err;
                });
        }

错误:

SyntaxError: Unexpected token ...

再次遵循的步骤

根据SE Query to Configure Babel with Webstorm for node.js project我尝试创建一个 node.js 应用程序,但现在收到错误:

 Error: querySrv ENOTFOUND _mongodb._tcp.undefined-p8e7q.mongodb.net
  at errnoException (dns.js:50:10)
    at QueryReqWrap.onresolve [as oncomplete] (dns.js:244:19)
  code: 'ENOTFOUND',
  errno: 'ENOTFOUND',
  syscall: 'querySrv',
  hostname: '_mongodb._tcp.undefined-p8e7q.mongodb.net' 

我现在将 { ...result._doc } 替换为 return result._doc 并且代码工作正常,但我希望在其他 block 中使用展开运算符代码。

我知道该错误与 Webstorm 无关,但我没有看到此问题的任何其他替代方法

编辑

文件观察器 Babel File Watcher for WebStorm

NPM 配置 NPM Configuration

Node.js 配置 通过右键单击 app.js 文件并从菜单中创建“app.js” 创建。我安装了 npm i --save-dev @babel/register 并将其更改为 -r @babel/register 如博客中所述 Node JS configuration

app.js

const express = require('express'); // Add Express Module
const bodyParser = require('body-parser'); // Add Body-Parser Middleware for JSON handling in Requests
const graphqlHttp = require('express-graphql'); // Add Middleware for GraphQL Resolvers over Express HTTP
const { buildSchema } = require('graphql'); // Javascript Object-Destructuring (pull objects from packages)
const mongoose = require('mongoose'); // MongoDB Third-Party package


const Event = require('./models/event'); // MongoDB Event Model

const app = express();

app.use(bodyParser.json()); // JSON parsing Middleware added

app.use('/graphql', graphqlHttp({
    schema: buildSchema(`
        type Event {
            _id: ID!
            title: String!
            description: String!
            price: Float!
            date: String!
        }

        input EventInput {
            title: String!
            description: String!
            price: Float!
            date: String!
        }

        type RootQuery {
            events: [Event!]!
        }

        type RootMutation {
            createEvent(eventInput: EventInput): Event
        }

        schema {
            query: RootQuery
            mutation: RootMutation
        }
    `),
    rootValue: {
        events: () => {
            return Event.find()
                .then(events => {
                    return events.map( event => {
                        event._doc._id = event.id;
                        return event._doc;
                    });
                })
                .catch(err => {
                    console.log(err);
                    throw err;
                })
        },
        createEvent: (args) => {
            const event = new Event({
               title: args.eventInput.title,
               description: args.eventInput.description,
               price: +args.eventInput.price,
               date: new Date(args.eventInput.date)
            });
            return event
                .save()
                .then(result => {
                    console.log(result);
                    return { ...result._doc };
                    // return result._doc
                })
                .catch(err => {
                    console.log(err);
                    throw err;
                });

        }
    },
    graphiql: true
}));

mongoose.connect(
    `mongodb+srv://${process.env.MONGO_USER}:${process.env.MONGO_PASSWORD}@${process.env.MONGO_CLUSTER_NAME}-p8e7q.mongodb.net/${process.env.MONGO_DB_NAME}?retryWrites=true`)
    .then( () => {
        app.listen(3000);
    }).catch(err => {
        console.log(err);
    });

package.json

我添加了一些奇怪的 babel 包,作为一些绝望的尝试来启动并运行它,这些包位于 dev-dependencies

{
  "name": "graphql-express-app",
  "version": "0.0.4",
  "description": "Academind's YouTube Series on GraphQL-Express-React",
  "main": "app.js",
  "scripts": {
    "test": "echo \"Error: no test specified\" && exit 1",
    "start": "nodemon app.js"
  },
  "keywords": [
    "graphql",
    "express",
    "node.js"
  ],
  "author": "",
  "license": "ISC",
  "dependencies": {
    "@babel/preset-stage-2": "^7.0.0",
    "babel-preset-stage-2": "^6.24.1",
    "body-parser": "^1.18.3",
    "express": "^4.16.4",
    "express-graphql": "^0.7.1",
    "graphql": "^14.0.2",
    "mongoose": "^5.4.1"
  },
  "devDependencies": {
    "@babel/cli": "^7.2.3",
    "@babel/core": "^7.2.2",
    "@babel/plugin-proposal-object-rest-spread": "^7.2.0",
    "@babel/preset-env": "^7.2.3",
    "@babel/register": "^7.0.0",
    "babel-cli": "^6.26.0",
    "babel-plugin-transform-es2015-destructuring": "^6.23.0",
    "babel-plugin-transform-object-rest-spread": "^6.26.0",
    "nodemon": "^1.18.9"
  }
}

最佳答案

我精简了您的示例,并添加了启动和运行所需的最小版本。

基本上,您缺少的是 babel 实际执行并转译代码的部分。我不知道 webstorm 是否可以为你做到这一点,我正在使用 VS code。

.babelrc:

{
    "presets": ["@babel/preset-env"],
    "plugins": ["@babel/plugin-proposal-object-rest-spread"]
}

package.json(仅依赖项和脚本,其余省略):

"scripts": {
  "test": "echo \"Error: no test specified\" && exit 1",
  "start": "nodemon --exec babel-node app.js"
},
"devDependencies": {
  "@babel/core": "^7.2.2",
  "@babel/node": "^7.2.2",
  "@babel/plugin-proposal-object-rest-spread": "^7.2.0",
  "@babel/preset-env": "^7.2.3",
  "nodemon": "^1.18.9"
}

最小app.js:

const o = {
  a: 'a',
  b: 'b',
};
const o2 = { ...o };
console.log(o2);
// Outputs: { a: 'a', b: 'b' }

通过使用最新版本,您可以免去转译 Nodejs 代码的麻烦。从版本 8.6.0 开始, Node 支持扩展运算符: https://node.green/#ES2018-features-object-rest-spread-properties

希望有帮助!

关于node.js - 即使在 Webstorm 2018.3 中进行 Babel 配置后,Spread Operator 也会抛出 SyntaxError,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54026224/

相关文章:

javascript - Mongoose 中的链静态方法不起作用

ide - Webstorm 项目 Pane 中缺少文件夹

javascript - 要求未定义? Todd Motto Angular 1.5 入门教程

json - node.js:将 json 数组转换为 csv

node.js - 向 Mongoose 注册模型的正确方法

javascript - 如何设置一个非常快的 node.js UDP 服务器

angularjs - 使用 WebStorm 调试 Protractor

phpstorm - WebStorm 6 中的自动格式化代码类似于 Sublime 文本对齐插件

javascript - AVA + React-Native 的测试配置

javascript - ES6 全局变量在类中不可用