解决node终端下运行js文件不支持ES6语法


Posted in Javascript onApril 04, 2020

最近写一些简单的测试代码时,为了方便直接在node终端执行发现有些ES6语法不支持,记录一下解决方式

现象

新建class.js文件后添加如下代码

// constructer
class Person {
 constructor(name,age,sex) {
  this.name = name;
  this.age = age;
  this.sex = sex;
 }
 getInfo() {
  return `name:${this.name},age:${this.age},sex:${this.sex}`;
 }

}
var jone = new Person('jone', 18, 'man');
console.log(jone.name);
export default Person;

在终端中运行代码会提示如下错误

解决node终端下运行js文件不支持ES6语法

不识别export关键字,因为node环境中的模块导入导出是CommonJS规范实现的,使用的关键字分别是 require和exports。 ( 其他比较流行的还有AMD方式的requirejs以及CMD方式的seajs )

查看ES6支持的语法

我们可以查看一下node环境下支持的ES6语法
可以先通过node -v 命令查看一下版本,可以看到我本地的版本是10.16.2

解决node终端下运行js文件不支持ES6语法

接着全局安装一下npm包

npm install -g es-checker

安装完成后就可以通过执行es-checker命令查看node的支持率及详情

可以看到如下输出,

解决node终端下运行js文件不支持ES6语法

最末尾显示的是

解决node终端下运行js文件不支持ES6语法

表示不支持模块方法

babel

怎么解决呢,可以通过添加babel命令,将代码转换为被支持的写法

在项目的工程目录下,也就是package.json同级目录下执行

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

其中babel-cli使我们可以在终端中使用babel命令,如同webpack对应的webpack-cli包,而babel-preset-* 是babel转换代码时所依赖的前置规则的插件集合,安装完成后,在同目录下配置使用babel,新建.babelrc文件,文件中输入如下配置

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

其中presets字段里添加我们的转换规则,可以只写前边提到的babel-preset- 对应的关键字作为缩写,plugins中可以配置一些定义转换规则的插件。
配置完成后,就可以在我的终端中用babel对我的代码进行转换了,直接执行babel命令babel class.js 可以看到我们的代码被转换成了ES2015的版本。如下

PS D:\git\study\mytest> babel src/Object/class.js
'use strict';

Object.defineProperty(exports, "__esModule", {
 value: true
});

var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();

function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }

// constructer
var Person = function () {
 function Person(name, age, sex) {
  _classCallCheck(this, Person);

  this.name = name;
  this.age = age;
  this.sex = sex;
 }

 _createClass(Person, [{
  key: 'getInfo',
  value: function getInfo() {
   return 'name:' + this.name + ',age:' + this.age + ',sex:' + this.sex;
  }
 }]);

 return Person;
}();

var jone = new Person('jone', 18, 'man');
console.log(jone.name);
exports.default = Person;

如果要直接在终端中执行呢,可以用如下命令babel-node xxxx,xxxx表示对应的目录及文件

解决node终端下运行js文件不支持ES6语法

这样,我们就可以在终端中执行大部分的ES6代码了,也可以在学习新语法的时候,通过babel转换成老的语法来帮助自己理解原理。

到此这篇关于解决node终端下运行js文件不支持ES6语法的文章就介绍到这了,更多相关解决node终端下运行js文件不支持ES6语法内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Javascript 相关文章推荐
基于PHP+Jquery制作的可编辑的表格的代码
Apr 10 Javascript
jquery插件制作 手风琴Panel效果实现
Aug 17 Javascript
javascript教程:关于if简写语句优化的方法
May 17 Javascript
使用jQuery的attr方法来修改onclick值
Jul 07 Javascript
jQuery实现弹窗居中效果类似alert()
Feb 27 Javascript
使用grunt合并压缩js和css文件的方法
Mar 02 Javascript
ECMAscript 变量作用域总结概括
Aug 18 Javascript
bootstrap 点击空白处popover弹出框隐藏实例
Jan 24 Javascript
vue-cli webpack2项目打包优化分享
Feb 07 Javascript
vue引入axios同源跨域问题
Sep 27 Javascript
JS如何把字符串转换成json
Feb 21 Javascript
javascript中call,apply,bind的区别详解
Dec 11 Javascript
jQuery 图片查看器插件 Viewer.js用法简单示例
Apr 04 #jQuery
jQuery实现鼠标放置名字上显示详细内容气泡提示框效果的方法分析
Apr 04 #jQuery
vue中使用v-for时为什么不能用index作为key
Apr 04 #Javascript
详解为什么Vue中不要用index作为key(diff算法)
Apr 04 #Javascript
原理深度解析Vue的响应式更新比React快
Apr 04 #Javascript
Vue的data、computed、watch源码浅谈
Apr 04 #Javascript
VUE table表格动态添加一列数据,新增的这些数据不可以编辑(v-model绑定的数据不能实时更新)
Apr 03 #Javascript
You might like
dedecms后台验证码总提示错误的解决方法
2007/03/21 PHP
php下载远程文件类(支持断点续传)
2008/11/14 PHP
PHP中PDO的错误处理
2011/09/04 PHP
传智播客学习之java 反射
2009/11/22 Javascript
javascript两段代码,两个小技巧
2010/02/04 Javascript
javascript对select标签的控制(option选项/select)
2013/01/31 Javascript
jQuery的3种请求方式$.post,$.get,$.getJSON
2014/03/28 Javascript
jquery 实现两Select 标签项互调示例代码
2014/09/25 Javascript
对Web开发中前端框架与前端类库的一些思考
2015/03/27 Javascript
js淡入淡出的图片轮播效果代码分享
2015/08/24 Javascript
微信小程序支付功能 php后台对接完整代码分享
2018/06/12 Javascript
详解Webpack loader 之 file-loader
2018/11/07 Javascript
深入解析ES6中的promise
2018/11/08 Javascript
JavaScript动态创建二维数组的方法示例
2019/02/01 Javascript
Easyui 关闭jquery-easui tab标签页前触发事件的解决方法
2019/04/28 jQuery
JavaScript交换两个变量方法实例
2019/11/25 Javascript
[06:24]DOTA2 2015国际邀请赛中国区预选赛第二日TOP10
2015/05/27 DOTA
[01:09:13]DOTA2-DPC中国联赛 正赛 CDEC vs XG BO3 第三场 1月19日
2021/03/11 DOTA
[31:47]夜魇凡尔赛茶话会 第三期01:选手知多少
2021/03/11 DOTA
Python列表list排列组合操作示例
2018/12/18 Python
python使用递归的方式建立二叉树
2019/07/03 Python
对Python生成器、装饰器、递归的使用详解
2019/07/19 Python
django foreignkey外键使用的例子 相当于left join
2019/08/06 Python
Python小白不正确的使用类变量实例
2020/05/29 Python
python 用Matplotlib作图中有多个Y轴
2020/11/28 Python
中层竞聘演讲稿
2014/01/09 职场文书
员工安全生产承诺书
2014/05/22 职场文书
测控技术自荐信
2014/06/05 职场文书
市场营销工作计划书
2014/09/15 职场文书
标准大学生职业生涯规划书写作指南
2014/09/18 职场文书
微笑面对生活演讲稿
2014/09/23 职场文书
仓库保管员岗位职责
2015/02/09 职场文书
2015年审计人员工作总结
2015/05/26 职场文书
详解前端任务构建利器Gulp.js使用指南
2021/04/30 Javascript
CSS+HTML 实现顶部导航栏功能
2021/08/30 HTML / CSS
使用redis生成唯一编号及原理示例详解
2021/09/15 Redis