Node.js中的导入导出

Node.js中的导入导出

一.CommonJs标准

导出语法:

javascript 复制代码
module.exports = {
  对外属性名: 模块内私有变量
}

导入语法:

javascript 复制代码
const 变量名 = require('模块名或路径')
// Node.js 环境内置模块直接写模块名(例如:fs,path,http)
// 自定义模块:写模块文件路径(例如:./utils.js)

代码实现

utils.js:导出

javascript 复制代码
/**
 * 目标:基于 CommonJS 标准语法,封装属性和方法并导出
 */
const baseURL = 'http://hmajax.itheima.net'
const getArraySum = arr => arr.reduce((sum, item) => sum += item, 0)

// 导出
module.exports = {
  url: baseURL,
  arraySum: getArraySum
}

index.js:导入使用

javascript 复制代码
/**
 * 目标:基于 CommonJS 标准语法,导入工具属性和方法使用
 */
// 导入
const obj = require('./utils.js')
console.log(obj)
const result = obj.arraySum([5, 1, 2, 3])
console.log(result)

二.ECMAScript标准

CommonJS 规范是 Node.js 环境中默认的,后来官方推出 ECMAScript 标准语法。

1.默认导入导出

导出语法:

javascript 复制代码
export default {
  对外属性名: 模块内私有变量
}

导入语法:

javascript 复制代码
import 变量名 from '模块名或路径'

注意:Node.js 默认只支持 CommonJS 标准语法,如果想要在当前项目环境下使用 ECMAScript 标准语法,请新建 package.json 文件设置

{ type: 'module' } 来进行设置

代码实现:

utils.js:导出

javascript 复制代码
/**
 * 目标:基于 ECMAScript 标准语法,封装属性和方法并"默认"导出
 */
const baseURL = 'http://hmajax.itheima.net'
const getArraySum = arr => arr.reduce((sum, item) => sum += item, 0)

// 默认导出
export default {
  url: baseURL,
  arraySum: getArraySum
}

index.js:导入

javascript 复制代码
/**
 * 目标:基于 ECMAScript 标准语法,"默认"导入,工具属性和方法使用
 */
// 默认导入
import obj from './utils.js'
console.log(obj)
const result = obj.arraySum([10, 20, 30])
console.log(result)

2.命名导出和导入

export 修饰定义语句

javascript 复制代码
export 修饰定义语句

命名导入语法:

javascript 复制代码
import { 同名变量 } from '模块名或路径'

注意:同名变量指的是模块内导出的变量名

代码示例:

utils.js 导出

javascript 复制代码
/**
 * 目标:基于 ECMAScript 标准语法,封装属性和方法并"命名"导出
 */
export const baseURL = 'http://hmajax.itheima.net'
export const getArraySum = arr => arr.reduce((sum, item) => sum += item, 0)

index.js 导入

javascript 复制代码
/**
 * 目标:基于 ECMAScript 标准语法,"命名"导入,工具属性和方法使用
 */
// 命名导入
import {baseURL, getArraySum} from './utils.js'
console.log(obj)
console.log(baseURL)
console.log(getArraySum)
const result = getArraySum([10, 21, 33])
console.log(result)

与默认导出如何选择:

  • 按需加载,使用命名导出和导入
  • 全部加载,使用默认导出和导入
相关推荐
前端小蜗3 分钟前
🌐 利用Chrome内置 【AI翻译 API】实现国际化
前端·javascript·浏览器
寒月霜华3 分钟前
JaveWeb后端-Web基础-SpringBoot Web、HTTP协议
前端·spring boot·http
袁煦丞4 分钟前
管家婆远程开单自由飞!管家婆系统:cpolar内网穿透实验室第646个成功挑战
前端·程序员·远程工作
Dontla5 分钟前
前端V0介绍(Vercel推出的AI前端生成工具)
前端·人工智能
fury_1235 分钟前
vue3:trycatch里面可以在写一个trycatch吗
前端
怪只怪满眼尽是人间烟火5 分钟前
Linux端口监控脚本
运维·javascript
苏纪云12 分钟前
ES6~ES11新特性
前端·ecmascript·es6
阿金要当大魔王~~17 分钟前
uniapp 请求携带数据 \\接口传值 \\ map遍历数据
前端·javascript·uni-app
十铭忘20 分钟前
基于SAM2的眼动数据跟踪2
java·服务器·前端
hey_ner22 分钟前
页面PDF文件格式预览(不使用pdf.js)
前端·javascript