1

我有一个 ES6 类,我试图将其导出为模块,但是我收到错误SyntaxError: Unexpected reserved word

汽车.js

class Car {
    constructor(make) { 
        this.make = make;
        this.currentSpeed = 25;
    }

    printCurrentSpeed(){
          console.log(this.make + ' is going ' + this.currentSpeed + ' mph.');
    }
}

module.exports = Car;

我正在尝试像这样使用 Car 模块

main.js

var Car = require("./models/Car");

let must = new Car('Mustang');
console.log(must.printCurrentSpeed());

我正在使用带有 babelify 的 browserify 转换为 ES6

browserify -t babelify main.js -o public/scripts/bundle.js",

我是否正确导出了 Car 模块,还是我做错了什么?

4

3 回答 3

2

需要 babel/register 会解决您的问题吗?

require('babel/register');

如此处所述:https ://babeljs.io/docs/usage/require/

节点所需的所有后续文件扩展名为 .es6、.es、.jsx 和 .js 将由 Babel 转换。polyfill 也是自动需要的。

于 2015-06-03T02:48:30.270 回答
1

我的问题是我正在开发一个同构的 React.js 应用程序并且 babelify browserify 转换很好,并且我的 bundle.js 文件被很好地转译了。这是我脚本的服务器端部分的问题,因为它没有使用 babel 编译为 ES6。

我希望这并不意味着我需要在我的源文件中复制我的 ES6 和 ES5,因为这是我试图避免的,并且通过 browserify babelify 转换,我能够在 ES6 中编写代码并指向main.js 文件。

这是我基于此的示例反应服务器存储库,我基本上是使用node-jsx从节点内透明地 require() jsx,所以我只需要一种方法来使用 babel 来做到这一点。

require('node-jsx').install(); 
var express = require('express');
var React = require('react');
var APP = require('./app'); // the JSX app with calls to ES6 modules
var app = express();
var port = 3000;
var ip = '127.0.0.1';

app.get('/', function(req, res) {
  var markup = React.renderToString(APP());
  res.send(markup);
});

更新:我认为与这个问题类似,我可以使用babel-node或使用带有 --harmony 标志的节点来运行具有 es6 功能的脚本

于 2015-03-30T11:55:05.080 回答
0

答案是我可以使用babel-node或使用带有 --harmony 标志的 node 来运行具有 es6 功能的脚本。

以下是一些示例 alt/iso 同构 React 示例babel-node server,用于演示这种方法。

于 2015-06-03T03:27:40.193 回答