js模块化开发

这篇具有很好参考价值的文章主要介绍了js模块化开发。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

◼ 到底什么是模块化、模块化开发呢?
 事实上模块化开发最终的目的是将程序划分成一个个小的结构;
 这个结构中编写属于自己的逻辑代码,有自己的作用域,定义变量名词时不会影响到其他的结构;
 这个结构可以将自己希望暴露的变量、函数、对象等导出给其结构使用;
 也可以通过某种方式,导入另外结构中的变量、函数、对象等;
◼ 上面说提到的结构,就是模块;按照这种结构划分开发程序的过程,就是模块化开发的过程;
◼ 无论你多么喜欢JavaScript,以及它现在发展的有多好,它都有很多的缺陷:
 比如var定义的变量作用域问题;
 比如JavaScript的面向对象并不能像常规面向对象语言一样使用class;
 比如JavaScript没有模块化的问题;

◼ 但是随着前端和JavaScript的快速发展,JavaScript代码变得越来越复杂了:
 ajax的出现,前后端开发分离,意味着后端返回数据后,我们需要通过JavaScript进行前端页面的渲染;
 SPA的出现,前端页面变得更加复杂:包括前端路由、状态管理等等一系列复杂的需求需要通过JavaScript来实现;
 包括Node的实现,JavaScript编写复杂的后端程序,没有模块化是致命的硬伤;
◼ 所以,模块化已经是JavaScript一个非常迫切的需求:
 但是JavaScript本身,直到ES6(2015)才推出了自己的模块化方案;
 在此之前,为了让JavaScript支持模块化,涌现出了很多不同的模块化规范:AMD(x)、CMD(x)、CommonJS等;
 

????

js模块化开发,javascript,开发语言,ecmascript

CommonJS


◼ 我们需要知道CommonJS是一个规范,最初提出来是在浏览器以外的地方使用,并且当时被命名为ServerJS,后来为了体现它的广泛性,修改为CommonJS,平时我们也会简称为CJS。
 Node是CommonJS在服务器端一个具有代表性的实现;
 Browserify是CommonJS在浏览器中的一种实现;
 webpack打包工具具备对CommonJS的支持和转换;
◼ 所以,Node中对CommonJS进行了支持和实现,让我们在开发node的过程中可以方便的进行模块化开发:
 在Node中每一个js文件都是一个单独的模块;
 这个模块中包括CommonJS规范的核心变量:exports、module.exports、require;
 我们可以使用这些变量来方便的进行模块化开发;
◼ 前面我们提到过模块化的核心是导出和导入,Node中对其进行了实现:
 exports和module.exports可以负责对模块中的内容进行导出;
 require函数可以帮助我们导入其他模块(自定义模块、系统模块、第三方库模块)中的内容;

common-js的使用

1.直接获取导出的对象, 从对象中获取属性

util.js

const UTIL_NAME = "util_name"
 
function formatCount() {
  return "200万"
}
 
function formatDate() {
  return "2022-10-10"
}
 
console.log(exports) // {}
 
exports.UTIL_NAME = UTIL_NAME
exports.formatCount = formatCount
exports.formatDate = formatDate

 main.js

// 1.直接获取导出的对象, 从对象中获取属性
const util = require("./util.js")
 
console.log(util.UTIL_NAME)
console.log(util.formatCount())
console.log(util.formatDate())

js模块化开发,javascript,开发语言,ecmascript

//2.导入对象之后, 直接对其进行解构
const { 
  UTIL_NAME,
  formatCount, 
  formatDate 
} = require("./util.js")
 
console.log(UTIL_NAME)
console.log(formatCount())
console.log(formatDate())

????

js模块化开发,javascript,开发语言,ecmascript

js模块化开发,javascript,开发语言,ecmascript 

foo.js

const name = "foo"
const age = 18
function sayHello() {
  console.log("sayHello")
}
 
// 1.在开发中使用的很少
// exports.name = name
// exports.age = age
// exports.sayHello = sayHello
 
// 2.将模块中内容导出
// 结论: Node导出的本质是在导出module.exports对象
// module.exports.name = name
// module.exports.age = age
// module.exports.sayHello = sayHello
 
// // console.log(exports.name, "----")
// // console.log(exports.age, "----")
// // console.log(exports.sayHello, "----")
// console.log(exports === module.exports)
 
// 3.开发中常见的写法
module.exports = {
  name,
  age,
  sayHello
}
 
// exports.name = "哈哈哈哈"
// module.exports.name = "哈哈哈哈"

 main.js

const foo = require("./foo.js")
 
console.log(foo.name)
console.log(foo.age)
foo.sayHello()

js模块化开发,javascript,开发语言,ecmascript

js模块化开发,javascript,开发语言,ecmascript 

 文章来源地址https://www.toymoban.com/news/detail-545666.html

到了这里,关于js模块化开发的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 第四章认识Node.js模块化开发

    Node.js系统模块 续上一篇文章第三章认识Node.js模块化开发-CSDN博客,这次继续来认识和总结以下node的常用模块开发 Node.js系统模块是指Node.js自带的一些模块,这些模块可以直接在Node.js中使用,无需安装其他包。以下是常用的Node.js系统模块: fs模块:用于处理文件系统。 htt

    2024年02月08日
    浏览(29)
  • Node.js开发、CommondJS 、ES-Module模块化设计

    目录  Node.js是什么 基础使用 Node的REPL 全局变量  模块化设计 CommondJS规范  基础使用exports和module.exports require  CommondJS优缺点 AMD和CMD规范 ES_Module  基本使用方法 导出 导入  结合使用 默认导出 ES Module解析流程  Node与浏览器的对比  在浏览器中,HTML与CSS交给Blink处理,如果其

    2023年04月21日
    浏览(26)
  • 【Go 基础篇】Go语言包详解:模块化开发与代码复用

    在Go语言中, 包(Package) 是一种用于组织代码的机制,用于将相关的函数、类型和变量等组织在一起,以便于模块化开发和代码复用。包的使用能够使程序结构更加清晰、可维护性更高,同时也是Go语言强调的一项重要特性。本篇博客将深入探讨Go语言中包的相关知识,包括

    2024年02月11日
    浏览(22)
  • JavaScript模块化

    JavaScript模块化,让我们通过一个实际的例子来更好地理解。 假设我们正在开发一个简单的购物车应用,需要实现计算商品总价和展示购物车列表的功能。我们可以将这个应用划分为两个模块:`cart.js`和`main.js`。 1. cart.js模块: ```javascript // cart.js // 定义一个私有变量,用于存

    2024年02月14日
    浏览(38)
  • JavaScript中的模块化编程

    JavaScript是一种强大的编程语言,它可以在浏览器中进行客户端脚本编写,并且在服务器端也有广泛的应用。随着JavaScript应用的增多,JavaScript代码的复杂度也不断增加。为了提高代码的可维护性和重用性,模块化编程变得越来越重要。本文将讨论JavaScript中的模块化编程,包括

    2024年02月02日
    浏览(36)
  • JavaScript:模块化【CommonJS与ES6】

    在 JavaScript 编程中,随着项目的复杂性增加,代码的组织和管理变得至关重要。模块化是一种强大的编程概念,它允许我们将代码划分为独立的模块,提高了可维护性和可扩展性。本文将详细介绍 CommonJS 和 ES6 模块,帮助你理解它们的特点和用法。 1. CommonJS 模块化 CommonJS 是

    2024年02月13日
    浏览(32)
  • JS模块化系统

    随着 JavaScript 开发变得越来越广泛,命名空间和依赖关系变得越来越难以处理。人们已经开发出不同的解决方案以模块系统的形式来解决这个问题。 CommonJS 是一种同步加载模块的规范,主要用于服务器端的 Node.js 环境。 top:CommonJS 加载的是一个对象(即 module.exports 属性),

    2024年02月19日
    浏览(32)
  • js 模块化

    模块化主要是用来抽离公共代码,隔离作用域,避免变量冲突等。 模块化的整个发展历史如下: IIFE :使用自执行函数来编写模块化,特点:在一个单独的函数作用域中执行代码,避免代码冲突。 AMD :使用 require 来编写模块化,特点:依赖必须提前声明好。 CMD :使用 seaJS

    2024年02月14日
    浏览(30)
  • 【前端模块化】JS模块化思想以及相关规范(CommonJS、ES module)

    1.模块化概念 随着前端应用日趋复杂,项目代码也大量膨胀,模块化就是一种最主流的代码组织方式, 一个模块就是一个实现特定功能的文件 ,它通过把我们的复杂代码按照功能的不同,划分为不同的模块单独维护的这种方式,去提高我们的开发效率,降低维护成本。要用

    2024年02月01日
    浏览(38)
  • Node.js模块化

    说明:将复杂的程序文件,拆分多个文件的过程。模块的内部数据是私有的,不过模块可以暴露内部数据供其他模块使用。 说明:编码时是按照模块一个一个编码的,整个项目就是一个模块化的项目。 3.模块化的优势 说明: 提高代码的复用性:模块化可以将代码分解为可重

    2024年02月12日
    浏览(46)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包