require 和 import,都是为了JS模块化使用。最近项目中,因为多人协同开发,出现了一个项目中同时使用了require 和 import 引入依赖的情况。正常情况下,一个项目中最好是对引入方式做一个规范。下面我们就来看一下require 和 import的区别:

一.require
  require是Commonjs的规范,node应用是由模块组成的,遵从commonjs的规范。用法:

 a.js

function test (args) {
// body...
console.log(args);
} module.exports = {
test
};
b.js let { test } = require('./a.js'); test('this is a test.');

require的核心概念:在导出的文件中定义module.exports,导出的对象类型不予限定(可为任意类型)。在导入的文件中使用require()引入即可使用。本质上,是将要导出的对象,赋值给module这个对象的exports属性,在其他文件中通过require这个方法来访问exports这个属性。上面b.js中,require(./a.js) = exports 这个对象,然后使用es6取值方式从exports对象中取出test的值。

二.import
import是es6为js模块化提出的新的语法,import (导入)要与export(导出)结合使用。用法:

a.js:

export function test (args) {
// body...
console.log(args);
} // 默认导出模块,一个文件中只能定义一个
export default function() {...}; export const name = "lyn";
b.js: // _代表引入的export default的内容
import _, { test, name } from './a.js'; test(`my name is ${name}`);

三、commonjs模块与ES6模块的区别
    1.commonjs输出的,是一个值的拷贝,而es6输出的是值的引用;

2.commonjs是运行时加载,es6是编译时输出接口;

文章目录
概念
一、ES6模块化的使用
、es6中的export
、es6中的import
二、CommonJs规范的使用
、CommonJs中的exports
、CommonJs中的require
三、CommonJs规范与ES6中import的区别
、引入模块的不同点
、引入模块的性能不同点
、暴露模块的不同点
四、在nodeJs中怎么使用
概念
CommonJs是一种模块化规范,在ES6之前的,用于服务器端nodeJs和浏览器端。 ES6标准发布后,模块化标准是以export指令导出接口,以import引入模块。 但是在node模块中,我们依旧很多地方采用的是CommonJS规范
即:使用module.exports导出接口,使用require引入模块。 这两种方式我们或多或少都有用过,只是不了解这是2种不同的规范 一、ES6模块化的使用
es6中模块化靠export { }暴露导出模块,靠import ... from '...'引入模块 、es6中的export
模块js使用export命令输出变量 注意:这里输出的必须是变量,而不能是值(包括方法) 注意:export命令不需要=,只要后面跟一个变量即可 正确示例:
// 直接暴露
export var test = 'Michael'; // 设置变量暴露
var test = 'Michael';
export {
test
}
错误示例:
// 直接暴露
export ; //报错
// 设置变量暴露 var test = ;
export test; //报错 以上错误的原因,是因为export命令后面不是变量而是一个值,即使是赋值给了test,它也是一个值(方法同理)。
正确用法中是把值包在了对象里{ test }
、es6中的import
目标文件,使用import ... form '...'引入模块(前提是暴露模块正确) import命令引入没什么坑,主要延伸是结合ES6的解构赋值 普通引入示例
import fs from 'fs' //引入整个fs模块 var test = fs.star(....) //调用fs模块中的star方法 解构引入示例
import { stat,readFile } from 'fs' //引入fs模块中的stat,readFile方法,其余不引入 var test = star(....) //调用fs模块中的star方法 二、CommonJs规范的使用
CommonJs规范靠exports.xx = xx或module.exports = { xx }暴露导出模块。
靠var xx = require('...')或var { stat, exists, readFile } = require('fs');引入模块 、CommonJs中的exports
注意:这里的exports不是一个命令
注意:这里的exports是有s的,且后面需要使用=,这里我的理解,exports自身是变量,引入就是依靠这个变量进行的 使用exports示例
var test = ;
exports.test = test; 使用module.exports示例
var test = ;
module.exports = {
test
} 、CommonJs中的require
导入也没什么坑,同样可以使用解构 普通引入示例
var fs = require('fs') //引入整个fs模块 var test = fs.star(....) //调用fs模块中的star方法 解构引入示例
var { stat,readFile } = require('fs') //引入fs模块中的stat,readFile方法,其余不引入 var test = star(....) //调用fs模块中的star方法 三、CommonJs规范与ES6中import的区别
、引入模块的不同点
require('xx')可以直接作为一个对象,也就是可以直接当成变量来使用,不赋值。如:require('xx').star(...)
而es6的import ... form ...是固定写法,不能操作
、引入模块的性能不同点
CommonJs规范的引入require('xx')是“运行时加载” 而es6的import ... form ...是按需引入,编译过程按照import命令来选择编译 、暴露模块的不同点
在上面使用介绍,暴露模块的区别已经很明显了:
es6的export命令不用=暴露一个变量(一般为对象)
CommonJs的exports.xx=xx,是依靠exports变量自身来暴露的
四、在nodeJs中怎么使用
我们都知道es6是绝对通用的规范,且会更新到es7、es8等。而既然es6有模块化的方法,那么CommonJs规范将逐步被替换。
但是现在而言,import、export等很多es6命令,还需要依靠编译成es5来实现。
比如在vue-cli当中,es6的使用就需要依赖webpack的babel进行编译成es5。
所以在nodeJs中如果不引入babel或其他方法来编译es5的话,依旧需要老老实实使用CommonJs规范。
ndoeJs使用es6import、export命令的解决方法,可以看阮一峰老师的ECMAScript6,.mjs后缀文件名
本文参考阮一峰老师的ECMAScript6 与一些关于js编译与运行的博客

.

require与import的更多相关文章

  1. 转:彻底搞清楚javascript中的require、import和export

    原文地址:彻底搞清楚javascript中的require.import和export   为什么有模块概念 理想情况下,开发者只需要实现核心的业务逻辑,其他都可以加载别人已经写好的模块. 但是,Ja ...

  2. 008_Node中的require和import

    一.js的对象的解构赋值 https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Operators/Destructuri ...

  3. NodeJS中的require和import

    ES6标准发布后,module成为标准,标准的使用是以export指令导出接口,以import引入模块,但是在我们一贯的node模块中,我们采用的是CommonJS规范,使用require引入模块,使 ...

  4. vue 更新了vue-cli到最新版本后引发的问题: require和import、vue-loader的问题

    "vue-loader": "^12.1.0", "vue-loader": "^12.1.0", "vue- ...

  5. javascript中的require、import和export模块文件

    CommonJS 方式 文件输出如math.js: math.add = function(a,b){ return a+b; }exports.math = math; 文件引入: math = r ...

  6. JS 中的require 和 import 区别整理

    ES6标准发布后,module成为标准,标准的使用是以export指令导出接口,以import引入模块,但是在我们一贯的node模块中,我们采用的是CommonJS规范,使用require引入模块,使 ...

  7. Node中没搞明白require和import,你会被坑的很惨

    ES6标准发布后,module成为标准,标准的使用是以export指令导出接口,以import引入模块,但是在我们一贯的node模块中,我们采用的是CommonJS规范,使用require引入模块,使 ...

  8. require和import的使用

    一.前言 ES6标准发布后,module成为标准,标准的使用是以export指令导出接口,以import引入模块,但是在我们一贯的node模块中,我们采用的是CommonJS规范,使用require引 ...

  9. Node中导入模块require和import??

    转自:https://blog.csdn.net/wxl1555/article/details/80852326 S6标准发布后,module成为标准,标准的使用是以export指令导出接口,以im ...

随机推荐

  1. easyui textbox 赋值

    $('#fireInfo').textbox('setValue', tempData.fireInfo); $('#fireStartTime').datetimebox('setValue', t ...

  2. String类中常用的方法

    @Test public void demo(){ // 以下为String中的常用的方法及注释, 最常用的注释前有**标注 String s = "abcdefg123456"; ...

  3. 谷歌地图 API 开发之获取坐标以及街道详情

    自己的项目中有获取当前点击的坐标经纬度或者获取当前街道的信息的需求.估计这个对于新手来说,还是比较麻烦的,因为从官网上找这个也并不是很好找,要找好久的,运气好的可能会一下子找到. 献上自己写的测试案例 ...

  4. js中innerHTML和outerHTML的相同与不同

    innerHTML 属性设置或返回表格行的开始和结束标签之间的 HTML,包括标签. outerHTML  设置或获取对象及其内容的HTML形式,也就是标签和文本内容全都显示出来 innerText  ...

  5. 论文阅读 | Sentence-BERT: Sentence Embeddings using Siamese BERT-Networks

    简述 在文本语义相似度等句子对的回归任务上,BERT , RoBERTa 拿到sota. 但是,它要求两个句子都被输入到网络中,从而导致巨大开销:从10000个句子集合中找到最相似的sentence- ...

  6. 5G,仅仅是更快的网速吗?

    前不久参加了华为的Dev Summit 2020开发者大会,听到了关于5G的一些分享,刚好最近对5G有一些自己的思考,在此分享给大家. 什么是5G 在这里我不想列举各种晦涩难懂的术语,简单说来,5G就 ...

  7. 2.4G芯片SI24R1可替代NRF24L01P

    随着美金和原厂对价格的调控,NRF24L01P的价格越来越高,对终端制造的客户造成了不少的压力成本,但很多人又不原意花费更多的人力物力去重新改版. 小编今天就着重给大家介绍一款芯片,可以在不改板的情况 ...

  8. elasticsearch中mapping全解实战

    目录 Mapping简介 Mapping Type 分词器最佳实践 字段类型 text 类型 keyword 类型 date类型 object类型 nest类型 range类型 实战:同时使用keyw ...

  9. kubernetes-单机实验(入门)

    一.安装kubernetes   实验环境: centos7.0(建议使用7.5版本) 实验机器IP:192.168.1.4 安装方式:yum安装 需求环境:Tomcat+Mysql   1:关闭防火 ...

  10. Python3之Django连接mysql数据库

    一.mysql服务器 系统版本:CentOS6.8 IP :10.0.0.51 版本 1.授权root远程登录 grant all on *.* to 'root'@'%' identifide by ...