前端工程化(二)(精品、面试必备基础)(春招、秋招)

目录

什么是模块化?

事实上模块化开发最终的目的是将程序划分成一个个小的结构

这个结构中编写属于自己的逻辑代码,有自己的作用域,定义变量名词时不会影响到其他的结构;

CommonJS规范和Node关系

复制代码
 我们需要知道CommonJS是一个规范,最初提出来是在浏览器以外的地方使用,并且当时被命名为ServerJS,后来为了体现它
的广泛性,修改为CommonJS,平时我们也会简称为CJS。

Node 是 CommonJS在服务器端一个具有代表性的实现;
Browserify 是CommonJS在浏览器 中的一种实现;
webpack 打包工具具备对CommonJS的支持和转换;

模块化的核心

导入和导出
导出
exportsmodule.exports 可以负责对模块中的内容进行导出
require 函数可以帮助我们导入其他模块 (自定义、系统、第三方库模块)

exports 导出 & require 导入

exports是一个对象 ,我们可以在这个对象中添加很多个属性,添加的属性会导出;

导出

javascript 复制代码
let FriendName = "康康"
exports.FriendName = FriendName
// 两秒后, 修改一下 FriendName
setTimeout(()=>{
    exports.FriendName = "芜湖"
},2000)

导入

javascript 复制代码
const bar = require('./bar.js');
console.log(bar.FriendName)
setTimeout(() => console.log(bar.FriendName),5000)

结果

康康

芜湖

说明

也就是require通过各种查找方式,最终找到了exports这个对象;

并且将这个exports对象赋值给了bar变量;

bar变量就是exports对象了;

所以后面

setTimeout(()=>{

exports.FriendName = "芜湖"

},2000) 一定要 exports.FriendName 才可以修改 FriendName

模块加载(持续更新)

相关推荐
夜郎king1 小时前
湖南高考天气查询:基于 HTML5 与百度天气 API 实现页面展示
前端·html5·百度天气实践·天气信息可视化
云水一下8 小时前
TypeScript 从零基础到精通(五):高级类型与泛型
前端·javascript·typescript
counterxing8 小时前
vibe coding 之后,我更不想打字了
前端·agent·ai编程
copyer_xyf8 小时前
Python 模块与包的导入导出
前端·后端·python
研☆香9 小时前
es6新特性功能介绍(四)
前端·ecmascript·es6
微扬嘴角9 小时前
React篇1--JSX语法规则、组件、组件实例的3大特性
前端·react.js·前端框架
8Qi89 小时前
LeetCode 213:打家劫舍 II(House Robber II)—— 题解 ✅
算法·leetcode·职场和发展·动态规划
copyer_xyf9 小时前
Python venv 虚拟环境
前端·后端·python
橘右今9 小时前
2026 Java后端高频面试宝典
java·开发语言·面试
无聊的老谢9 小时前
Vue 3 + TypeScript 构建大型电信运维平台的前端架构设计
前端·vue.js·typescript