如何在 Node.js 中使用 import / export 的三种方法

2019-08-07 17:16:53

如何在 Node.js 中使用 import / export 的三种方法

因为一些历史原因,虽然 Node.js 已经实现了 99% 的 ES6 新特性,不过截止 2018.8.10,How To Enable ES6 Imports in Node.JS 仍然是老大难问题


下面我来介绍三种方法可以让我们在 Node.js 中使用 import/export 。


注:第1、2种方法均是借助 babel,需要注意的是文章使用的babel版本 < 7。从 babel 7.X 版本开始,部分包名、用法发生了些许变化,大体与7之前的用法类似,详细请到官方手册学习 7.X 版本的改动(Babel 踩坑总结(三) —— 7.X 版本升级是我对 7.X 版本三大改动的总结)


1. 使用 babel-register

1.1 下载必须的包

npm install babel-register babel-preset-env -D

1

1.2 修改你的 server.js

下面是一个 server.js 的例子:


const Koa = require('koa')

const app = new Koa()


app.listen(8225, console.log("application is start at port 8225"))

1

2

3

4

用 import 替换 require


import Koa from 'koa'

const app = new Koa()


app.listen(8225, console.log("application is start at port 8225"))

1

2

3

4

如果你现在用 node server.js 跑这个文件,你会收到像这样的错误提示:


/Users/zwkkkk1/myStudy/demo/chatroom/server/app.js:1

(function (exports, require, module, __filename, __dirname) { import Koa from 'koa'

                                                                     ^^^


SyntaxError: Unexpected identifier

1

2

3

4

5

下面让我们用 babel 来解决这个问题


1.3 新增一个 start.js 文件

这个文件将成为我们的入口文件,里面是一些 babel 的代码


require('babel-register') ({

    presets: [ 'env' ]

})


module.exports = require('./server.js')

1

2

3

4

5

注意,接下来不是 node server.js,而是用 node start.js 来启动这个文件


2. 使用 babel-node 命令

如果你不想添加新的文件也可以,这里需要在命令行中使用 babel-node 命令。babel-node 命令不是独立安装,在 Babel 7.X 版本前,需要通过安装 babel-cli 包获得;在 Babel 7.X 版本,需要安装 @babel/core、@babel/cli 两个包。


此处以 7.X 之前的版本举例,7.X 版本可去官网查找对应包的使用用例


安装必要的插件


全局安装 babel-cli


npm install babel-cli -g

1

安装 babel-preset-env


npm install babel-preset-env -D

1

然后原来是 node server.js,改为这样调用:babel-node --presets env server.js


需要注意的是如果只是为了 babel-node 这一个命令,安装 babel-cli 会加载安装很多资源和模块,出于性能考虑不推荐在生产环境使用。自己在开发调试的时候,可以鼓捣着玩玩


3. 来自 Node.js 官方的力量

Node 9提供了一个尚处于 Experimental 阶段的模块,让我们可以抛弃 babel 等一类工具的束缚,直接在 Node 环境下使用 import/export。


官方手册:ECMAScript Modules

一个不错的教程:Node 9下import/export的丝般顺滑使用

有兴趣的可以去了解一下,嫌字多的可以继续往下看看我总结的使用方法


用前须知

Node 版本需在 9.0 及以上

不加 loader 时候,使用 import/export 的文件后缀名必须为 .mjs

举个例子,还是用上面的例子,请将代码回退到 Babel 中第一步的样子


3.1 改写 server.js

import Koa from 'koa'

const app = new Koa()


app.listen(8225, console.log("application is start at port 8225"))

1

2

3

4

和前面一样,不过将文件名改一下,从 server.js 改为 server.mjs


3.2 启动文件

执行下面代码,来启动文件


node --experimental-modules ./server.mjs

1

注意这是引用 koa 第三方模块不用做其他变化,如果要 import 自己的文件,那么那个待引入的文件也要改后缀。


比如


import example from './example'

1

那么原来应该是 example.js 要改为 example.mjs


目前这个模块还处于实验阶段,还是不要放到生产环境,自己拿出来玩玩还是可以的,


  • 2018-12-13 17:17:02

    轻松实现动态获取Android手机CPU架构类型

    .so文件是unix的动态连接库,是二进制文件,作用相当于windows下的.dll文件。 他使用了C/C++代码编写的可以操作硬件比java更高级的 底层代码,执行速度和效率比其他语言要高。 在Android中调用动态库文件(*.so)都是通过jni的方式。

  • 2018-12-13 22:48:48

    Android MultiDex实践:如何绕过那些坑?

    MultiDex, 顾名思义,是指多dex实现,大多数App,解压其apk后,一般只有一个classes.dex文件,采用MultiDex的App解压后可以看到有classes.dex,classes2.dex,… classes(N).dex,这样每个dex都可以最大承载65k个方法,很大限度地缓解了单dex方法数限制。

  • 2018-12-14 13:32:18

    解决chrome调试手机模式没有鼠标问题

    F12后,切换到手机模式,方向没有鼠标,这对于调试前端页面来说无疑是一大难题,看不见只能盲点, 以为是浏览器问题,清理缓存,升级浏览器,清除插件等都不好使。 后来查到资料说是显卡问题。果然还真是显卡问题。

  • 2018-12-14 17:12:51

    Android APP适配全面屏手机的技术要点

    全面屏是手机业界对于超高屏占比手机设计的一个宽泛的定义。从字面上解释就是,手机的正面全部都是屏幕,四个边框位置都是采用无边框设计,追求接近100%的屏占比。但受限于目前的技术,还不能做到手机正面屏占比100%的手机。现在业内所说的全面屏手机是指真实屏占比可以达到80%以上,拥有超窄边框设计的手机。

  • 2018-12-14 17:15:50

    Android适配刘海屏沉浸式状态栏的一些坑

    18年简直是刘海元年,所有手机都在跟风刘海屏,甚至每个厂商还有自己的一套适配规范。我的初始需求很简单,就是做一个全屏显示的页面,一般情况下只需要开启Android规范的全屏模式就好:

  • 2018-12-16 12:12:12

    android:windowSoftInputMode属性具体解释

    android:windowSoftInputMode属性一共同拥有9个取值。各自是: stateUnspecified,stateUnchanged。stateHidden,stateAlwaysHidden。stateVisible,stateAlwaysVisible,adjustUnspecified,adjustResize。adjustPan。

  • 2018-12-16 18:14:23

    Android在代码中设置状态栏半透明/全透明

    顶部是有文字,小图标等,如果直接用透明半透明 状态栏上的东西会与内容重叠(你觉得无所谓也可以直接用上面2部分代码),这样我们就想做成类似支付宝这样的效果: