vue 导入、导出模块的几种方式

JavaScript018

vue 导入、导出模块的几种方式,第1张

ES6规范 模块导入方式:import

ES6规范 模块导出方式:export、export default

nodejs commonjs规范 模块导入方式:require

nodejs commonjs规范 模块导出方式:exports、module.exports

es6

import ... form...替代 require()

//不接收对象 require:require('s.css')//(es5)improt  's.css' //(es6)//接收对象var o = require('s.js')//es(5)import o form s.js    //(es6)

对象的写法

导出一个模块对象(es5):

module.exports={

add:add,    sub:sub}

导出一个模块对象(es6):module.exports={

add,    sub}

注意:这种写法属性名和属性值变量是同一个,否则要分开写module.exprots={

addFn:add,    sub}  

一个对象中方法的写法

//es5module.exports={

addFun:function(x,y){        return x+y

}

}//es6module.exports={

addFun(x,y){        return x+y

}

}

导出对象的写法

calc.js中有两个函数:

function add(){}

function sub(){}

//写法一

es5写法:

module.exports.add = add

module.exports.sub = sub

使用:

var calc = require('./calc.js')

es6写法:

exprot function add(){}

exprot function sub(){}

//写法二

es5:

module.exports = {add:add,sub:sub}

es6:

exprot default{

add,sub}

//表示取得calc.js中所有暴露出来的对象(es6)import calc from './calc.js'

//只获取到calc.js中的add方法(按需获取)import {add} from './calc.js'

用export 和import 的写法注意点

1、如果模块中是使用 export default {} 方式导出的对象

只能通过  import 对象名称 from '模块路径'

不能通过  import {对象名称} from '模块路径'2、如果就想要import {对象名称} from '模块路径'通过这种方式来按需导入对象中的某个属性

那么应该使用 export 跟着要导出的对象或者方法名称    export function add(){}    export function substrct(){}

那么就可以使用:    import {add,substrct} from '模块路径'

只需要直接使用 add()方法即可

注意这里不能直接使用:  import cacl from '模块路径' 这种方式导入,会报错

从版本

8.5.0

开始,Node.js

开始支持原生

ES

模块,可以通过命令行选项打开该功能。新功能很大程度上得归功于

Bradley

Farias。

1.演示

这个示例的代码目录结构如下:

esm-demo/

lib.mjs

main.mjs

lib.mjs:

export

function

add(x,

y)

{

return

x

+

y

}

main.mjs:

import

{add}

from

'./lib.mjs'

console.log('Result:

'+add(2,

3))

运行演示:

$

node

--experimental-modules

main.mjs

Result:

5

2.清单:需要注意的事情

ES

模块:

·不能动态导入模块。但是

动态import()

的相关工作正在进行中,应该很快就能提供支持。

·没有元变量,如

__dirname

__filename。但是,有一个的类似功能的提案:“import.meta”。看起来可能是这样:

console.log(import.meta.url)

·现在所有模块标识符都是

URL(这部分在

Node.js

是新增的):

·文件

-

带文件扩展名的相对路径:

../util/tools.mjs

·库

-

没有文件扩展名,也没有路径

lodash

·如何更好地使

npm

库在浏览器中也可用(不使用

bundler)仍有待观察。一种可能性是引入

RequireJS

风格的配置数据,将路径映射到实际路径。目前,在浏览器中使用

bare

path

的模块标识符是非法的。

CJS

模块的互操作性

你可以导入

CJS

模块,但它们总是只有默认的导出

-

module.exports

的值。让

CJS

模块支持命名导出已经在做了,但可能需要一段时间。如果你能帮忙,可以来做。

import

fs1

from

'fs'

console.log(Object.keys(fs1).length)

//

86

import

*

as

fs2

from

'fs'

console.log(Object.keys(fs2))

//

['default']

·

不能在

ES

模块中使用

require()。主要原因是:

· 路径解析工作稍有不同:ESM

不支持

NODE_PATH

require.extensions。而且,它的标识符始终是

URL

也会导致一些细微差异。

·

ES

模块始终以异步方式加载,这确保了与

Web

的最大兼容性。这种加载风格并不能通过

require()

混合使用同步加载

CJS

模块。

·

禁止同步模块加载也可以为

Top-level

await

导入

ES

模块保留后路(一个当前正在考虑的功能)。

3.早期版本的

Node.js

上的

ES

模块

如果要在

8.5.0

之前的

Node.js

版本上使用

ES

模块,请参阅

John-David

Dalton

@std/esm。

提示:如果不启用任何可解锁的额外功能,将在

Node.js

保持

100%

兼容原生

ES

模块.

FAQ

什么时候可以不带命令行选项使用ES

模块?

目前的计划是在

Node.js

10

LTS

中默认可使用

ES

模块。

进一步阅读

有关

Node.js

和浏览器中

ES

模块的更多信息:

·

“Making

transpiled

ES

modules

more

spec-compliant”

[using

ES

modules

natively

vs.

transpiling

them

via

Babel]

·

“Module

specifiers:

what's

new

with

ES

modules?”

[Why

.mjs?

How

are

module

specifiers

resolved?

Etc.]

·

“Modules”

[in-depth

chapter

on

ES

modules

in

“Exploring

ES6”]

即将到来的

ECMAScript

提案:

·

博客:

“ES

proposal:

import()

dynamically

importing

ES

modules”

·

提案:

“import.meta”

总结

以上就是小编给大家带来的在

Node.js

中使用原生

ES

模块方法解析的全部内容,希望对大家有所帮助。如果您有什么问题,可以给我留言。感谢大家对本站的支持。