JavaScript模块化开发规范及npm包管理器入门指南

JavaScript模块化开发规范及npm包管理器入门指南

JavaScript作为一门常用的编程语言,模块化开发规范和包管理工具对于项目开发至关重要。本指南将深入探讨ECMAScript模块标准规范、CommonJS规范以及npm包管理器的基本知识和使用方法。

JavaScript模块化开发规范

ECMAScript Module标准规范

  1. 导入导出变量

新建导出文件ex.js:

javascript 复制代码
let val = 'ex data'
export { val }

新建导入文件im.js:

javascript 复制代码
import { val } from "./ex.mjs"

console.log(val)

注意:在Node.js中可能需将文件后缀改为.mjs以解决报错。

  1. 导入导出使用as别名

更名导出变量:

javascript 复制代码
// ex.mjs
let val = 'ex data'
export { val as value }

// im.mjs
import { value as vv } from "./ex.mjs"
console.log(vv)
  1. 默认导出

默认导出变量:

javascript 复制代码
// ex.mjs
let val = 'ex data'
export default val;

// im.mjs
import val from "./ex.mjs"
console.log(val)
  1. 通过配置package.json解决报错

添加配置信息到package.json:

json 复制代码
{
  "type": "module"
}
  1. CommonJS规范

Node.js默认使用CommonJS规范,但ECMA Script Module提供更强大的模块化支持。

  1. 使用CommonJS实现模块化

新建m1.js导出:

javascript 复制代码
let val = 'this is commonjs'
module.exports = val

新建m2.js导入:

javascript 复制代码
const val = require("./m1")
console.log(val)

其他相关内容请参考上述具体规范。

npm包管理器

  1. 什么是npm

npm是JavaScript生态中常用的包管理工具,用于管理第三方包。 官网: www.npmjs.com 例子: json-server

  1. npm随Node.js一起安装

使用npm --version查看版本号。

  1. 常用npm命令
  • npm init:初始化项目,生成package.json文件。
  • 修改scripts选项,如"dev": "node a.js"
  • 运行npm run dev执行脚本。

示例a.js文件:

javascript 复制代码
console.log(123)

以上是JavaScript模块化开发规范及npm包管理器的入门指南,通过学习和实践这些内容,您将能更好地组织和管理JavaScript项目,提高开发效率。若大家有任何问题或需要进一步的解释,请留言反馈。感谢阅读!

相关推荐
2601_949817723 小时前
Spring Boot3.3.X整合Mybatis-Plus
spring boot·后端·mybatis
uNke DEPH3 小时前
Spring Boot的项目结构
java·spring boot·后端
zhenxin01224 小时前
Spring Boot 3.x 系列【3】Spring Initializr快速创建Spring Boot项目
spring boot·后端·spring
前端一小卒4 小时前
前端工程师的全栈焦虑,我用 60 天治好了
前端·javascript·后端
不停喝水4 小时前
【AI+Cursor】 告别切图仔,拥抱Vibe Coding: AI + Cursor 开启多模态全栈新纪元 (1)
前端·人工智能·后端·ai·ai编程·cursor
oyzz1204 小时前
Spring EL 表达式的简单介绍和使用
java·后端·spring
zhenxin01225 小时前
【wiki知识库】07.用户管理后端SpringBoot部分
spring boot·后端·状态模式
码事漫谈5 小时前
OpenSpec 简明教程
后端
程序员小假5 小时前
向量检索的流程是怎样的?Embedding 和 Rerank 各自的作用?
java·后端
后置的猿猴6 小时前
Spring 循环依赖
java·后端·spring