前端工程化

1、CMJ和ESM

1)commonjs和es6的区别?

  • CMJ是社区标准,ESM是官方标准;
  • CMJ是使用函数实现模块化的,ESM使用新语法实现模块化(import, export);
  • CMJ是动态依赖,同步执行;ESM既支持动态也支持静态,动态依赖是异步执行的;
  • CMJ仅在node环境中支持,ESM支持各种环境;
  • CMJ只是普通的函数调用和赋值,ESM导入时有符号绑定(如果模块的变量值发生变化,导入的模块会感知到这一变化)。

2)export和export default的区别?

  • export导出,也叫做具名导出,它的导出必须带有命名,在导出的模块对象中,命名即为模块对象的属性名,一个模块可有多个具名导出;
  • export default为默认导出,在模块对象中名称固定为default,无需命名,在一个模块中只有哟个默认导出。

2、NPX

  1. npx webpack:

寻找本地工程下的node_modules/.bin/webpack,如果将命令配置到package.json的scripts中,可以省略npx

2)npx 包名:先会在node_modules里面查找,没有的话会下载,放到临时目录,后续可能删掉

3、ESLint

1)一个工具,预先配置好各种规则,甚至自动修复

2)基本使用:

  • 安装eslint (npm i -D eslint )
  • 配置检查文件(./eslintrc ./eslintrc.js ./eslintrc.yml)(rules属性里面配置)
  • 安装插件eslint,在vscode里面可以自动检测
  • 引用别人自定义规则(npm i -D eslint-config-airbnb, 配置文件添加extends:'airbnb')
  • 检查单个文件 npx eslint ./src/index.js
  • eslintrc配置文件的模块(root, env,extends,parserOptions,rules)

4、webpack相关问题

1)webpack scope hosting:内置的优化,针对模块的优化,在生产环境打包时会自动开启。

未开启时,会将每个模块代码放置到一个独立的函数环境中,保证了模块作用域互不干扰;

开启之后会将多个模块的代码合并到一个函数环境,这样可以减少函数的调用,对运行效率有一定的提升,降低了打包体积。

开启的前提时,没有遇到某些模块多次被引用,没有动态导入的模块,或者是ESM模块

相关推荐
小鹏linux11 小时前
Ubuntu 22.04 部署开源免费具有精美现代web页面的Casdoor账号管理系统
linux·前端·ubuntu·开源·堡垒机
前端若水12 小时前
会话管理:创建、切换、删除对话历史
前端·人工智能·python·react.js
Bigger12 小时前
mini-cc:一个轻量级 AI 编程助手的诞生
前端·ai编程·claude
涵涵(互关)12 小时前
Naive-ui树型选择器只显示根节点
前端·ui·vue
BY组态12 小时前
Ricon组态系统最佳实践:从零开始构建物联网监控平台
前端·物联网·iot·web组态·组态
BY组态13 小时前
Ricon组态系统vs传统组态软件:为什么选择新一代Web组态平台
前端·物联网·iot·web组态·组态
SoaringHeart13 小时前
Flutter进阶:OverlayEntry 插入图层管理器 NOverlayZIndexManager
前端·flutter
放下华子我只抽RuiKe513 小时前
React 从入门到生产(四):自定义 Hook
前端·javascript·人工智能·深度学习·react.js·自然语言处理·前端框架
IT_陈寒14 小时前
Redis缓存击穿把我整不会了,原来还有这手操作
前端·人工智能·后端
idcu15 小时前
深入 Lyt.js 组件系统:L2 渲染引擎层的核心
前端·typescript