前端工程化筑基-Node/npm/babel/polyfill/webpack
00、前端搬砖框架
开发 ⇨ 构建 ⇨ 部署上线 ⇨ 摸鱼:
01、Node.js/npm
Node.JS 是一个基于 Chrome V8 引擎 的 JavaScript 运行时环境,不是JS库(是C++开发的),是用来解释执行JavaScript 代码的。我们开发Web应用中的JavaScript 代码都是运行在浏览器上,有了Node.JS,就可以用JavaScript 来开发中间件、后端服务了。
我们在VSCode中用到的很多组件都是基于Node.JS来开发运行的,如构建工具webpack、vue-cli。
1.1、什么是npm?
npm(Node Package Manager)为Node.JS的包管理器,用来管理JS组件模块的,包括安装、卸载、管理依赖等。很多语言都有自己的包管理器,如Java
的maven
、.Net
的Nuget
等。
npm仓库(registry):官方的 npm仓库 存放了大量的、几乎所有的 JS组件(轮子)。在这里,你会发现你不是一个人在战斗!大家开源的各种前端组件库都是发布到这个集中式的大仓库里,使用npm工具就可以从仓库里学习(copy)、安装使用各种组件了。
1.2、什么是yarn/pnpm?
yarn、pnpm的作用同npm一样,都是包管理工具,使用方式都比较相似。
- npm:这是Node.js官方自带的包管理工具,
- yarn:由于早期npm存在一些不完善的问题,于是一些大公司推出了yarn。
- npm完善:受yarn的反向推动,后来npm逐步升级完善。
- pnpm:一个比较新包管理工具,相比npm、yarn,有更好的下载速度、磁盘管理、依赖管理。
1.3、npm命令/配置
NodeJS官网 下载安装包,安装Node.JS的时候就自带npm了,可以直接使用。npm是一个命令行工具,指令都是在cmd命令行工具中执行的,常用指令如下:
常用指令 | 说明 |
---|---|
node -v | 查看nodeJS版本,也用来验证node是否安装 |
node | 进入node命令环境,可运行任何JavaScript代码了 |
console.log('hello world') | 在node环境中执行JS代码 |
npm -v | 查看npm版本 |
npm install -g <包名称@版本号> | 安装一个模块,@可指定版本号,-g 表示全局安装。npm install -g vuex@3 |
npm uninstall <包名称> | 卸载一个模块 |
npm update <包名称> | 更新模块 |
npm list -g | 查看所有全局安装的模块 |
npm list <包名称> | 查看模块的版本信息,npm list vuex |
npm init | npm初始化,会生成一个 package.json 文件 |
npm install | 自动安装 package.json 文件中的模块 |
npm install -save <包名称> | 在package 文件的dependencies 写入依赖,用于生产环境。简写 npm i -S |
npm install -save-dev <包名称> | 在package 文件的devDependencies 写入依赖,开发环境。简写:npm i -D |
npm cache clean -f | 清除缓存 |
配置本地的包存储目录:新建npm包的文件夹用于存放包的资源。
- 全局npm包存储路径
node_global
:npm config set prefix "D:\Project_Files\npm\node_global"
- npm包的缓存路径
node_cache
:npm config set cache "D:\Project_Files\npm\node_cache"
环境配置:修改环境变量:系统属性 ➤ 环境变量。重启一下VSCode、命令行工具才生效。
- ❶ 添加一个系统变量:系统变量 ➤ 新建:变量名=
NODE_PATH
,变量值= 上面准备好的全局npm
包的路径下的模块路径D:\Project_Files\npm\node_global\node_modules
。 - ❷ 添加Path路径:打开系统变量列表中的
Path
变量,新建一个值=全局npm路径D:\Project_Files\npm\node_global
到这里就完成了基础配置了,可以通过命令安装组件了。
npm仓库镜像:默认的npm仓库在国外,下载可能不稳定、比较慢,可以改为国内的淘宝镜像(每10分钟更新一次)。
- 查看包的仓库地址:
npm config get registry
- 设置仓库地址为淘宝镜像:
npm config set registry https://registry.npmmirror.com/
- 或者安装
cnmp
插件:npm install -g cnpm --registry=https://registry.npmmirror.com
在VSCode中使用:
设置
>> Terminal › Integrated › Default Profile: Windows
的选项值为一个命令行工具,推荐“Git Bash”,重启VS!就可以VSCode中的终端使用npm指令了。
1.4、package.json
每个项目都有一个 package.json 文件,内容是一个json对象。用于定义项目依赖的各种模块,及项目配置信息、模块的配置信息。命令 npm init -y
可创建一个初始package.json文件。
{
"name": "vuep3", //*项目/模块名称
"version": "0.1.0", //*项目版本,格式为:「主版本号. 次版本号. 修订号」
"private": true, //是否私有
"scripts": { //npm 脚本命令,通过 npm run 执行命令
"serve": "vue-cli-service serve", //启动vue-cli-server服务
"build": "vue-cli-service build", //编译
"test:unit": "vue-cli-service test:unit", //执行单元测试
"lint": "vue-cli-service lint" //执行代码检查?
},
"dependencies": { //生产环境项目依赖,通过"npm install -save <包名称>"安装组件,或"npm i -S"
"core-js": "^3.8.3", //key为模块名,value为模块版本号
"vue": "^2.6.14" //
},
"devDependencies": { //开发环境项目依赖,开发、编译中使用,不会输出到生产环境,安装指令:npm i -D
"@babel/core": "^7.12.16",
"@babel/eslint-parser": "^7.12.16",
"@vue/cli-plugin-babel": "~5.0.0",
"@vue/cli-plugin-eslint": "~5.0.0",
"@vue/cli-service": "~5.0.0",
"@vue/eslint-config-airbnb": "^6.0.0",
"eslint": "^7.32.0",
"eslint-plugin-import": "^2.25.3",
"eslint-plugin-vue": "^8.0.3",
"eslint-plugin-vuejs-accessibility": "^1.1.0",
"vue-template-compiler": "^2.6.14"
},
"eslintConfig": { //检查文件配置
"root": true,
"env": {"node": true},
"extends": [ "plugin:vue/essential", "@vue/airbnb" ],
"parserOptions": {"parser": "@babel/eslint-parser" },
"rules": {}
},
"browserslist": [ //项目需要兼容的浏览器配置,处理js、css兼容性是会用到
"> 1%",
"last 2 versions",
"not dead"
]
}
package.json文件中版本号的说明,版本号格式:「主版本号. 次版本号. 修订号」
。
~
:匹配最新的修改的版本号,"~1.2.3
" 匹配1.2.x
中最新的版本。^
:匹配最新的此版本+修订版本号,^1.2.3
会匹配1.x.x
中最新的版本。*
:匹配最新的x.x.x
版本。
02、babel/polyfill 为何物?
babel 是用来编译JavaScript代码的,解决JavaScript兼容性问题的。
2.1、什么是polyfill?
polyfill 意为 腻子 /垫片,目的是解决JavaScript代码的兼容性问题,解决方式就是用浏览器支持的方式模拟实现一遍。如ES2015+ 的很多不错的特性在一些古老的浏览器下存在兼容性问题,如异步promise
、map、新API方法等。于是就有了替代方案,如下示例代码,判断如果不支持promise
则模拟实现一个,这就称之为 polyfill
(polyfill/ˈpɒli fɪl/ 腻子脚本)。
window.Promise = (function(window){
if(window.Promise){
return window.Promise
}else{
window.Promise = function(){ } // 兼容代码,模拟实现
}
})(window)
于是各种各样的polyfill
就出现了,为了统一规范和管理,于是出现了 babel
!
2.2、什么是babel?
babel 是一个针对ECMScript语言兼容性处理的工具链,(babel /ˈbeɪbl/ 巴别塔,一座通往天堂的高塔,来自圣经的故事),将ES2015+的代码转译为向后兼容的JavaScript代码。其核心功能就是转译代码,转译过程简单来说,先对JS代码进行词法、语法分析抽象为语法树,然后对语法树进行变换和代码生成。第二步就有很多babel的工具链插件参与了,用于不同类型代码的转换生成。
babel能干什么?
- 语法转换,如let、const、箭头函数等新的语法。
polyfill
代码,如异步promise
、map、新API方法等。需引入插件,如@babel/polyfill
,由于存在全局污染+重复代码问题,被废弃;@babel/plugin-transform-runtime
代替- 其他代码转换,如TypeScript、JSX。
大量的冗余代码怎么办?
使用babel,可以在代码编译的时候就解决所有的JS兼容性问题。但问题是冗余JS代码会比较多,有些客户的浏览器比较先进,并不需要polyfill
(或只需要少量即可),也要加载这么多JS。于是有两个解决方法:
- 静态按需引入:在编译时指定需要兼容的浏览器及版本,按需引入
polyfill
,如@babel/preset-env
插件,useBuiltIns
参数设置需兼容的浏览器。 - 动态按需引入:把
polyfill
代码放到服务器上,客户端动态的判断浏览器的情况再请求polyfill
代码,如@polyfill.io
方案。
怎么使用?简单了解下
- 安装babel核心库,@babel/core
- 安装插件babel的工具链插件/预设(preset预设的插件集合)
- 通过
@babel/cli
指令,或者webpack、vue-cli来执行babel
编译转换。
2.3、Vue-cli中的babel
vue-cli中使用了@vue/babel-preset-app
预设,包含了babel-preset-env、JSX 支持以及为最小化包体积优化过的配置,可以通过 babel.config.js
进行配置。
03、webpack速览
vue-cli
是建立在webpack基础之上的,简化了繁琐的webpack配置和使用,先初步了解下webpack基本原理和流程。
3.1、webpack是干什么的?
webpack 是一个强大的前端构建工具,也是基于Node.js开发和运行,作用就是把开发态的各种代码编译(构建、打包)为浏览器可(更好)运行的代码。webpack配置灵活,包含丰富的扩展插件,webpack的各项能力也都是通过这些插件来完成的。
️核心作用:提高开发效率!
- 代码编译:提高写Bug效率,可以愉快的利用模块化、现代的ES6语法,及高级的CSS。
- CSS代码编译:less、sass的转换,CSS兼容性补全等。
- JS代码编译:ES6语法的兼容性转,利用
babel/polyfill
相关插件 - 代码校验:对CSS、JS代码的规范性校验检查,
ESLint
插件 - 热更新:开发态修改代码动态更新页面,实时预览,方便开发调试。
- 代码优化:
- 模块依赖,处理各种第三方组件的依赖,避免重复加载、冲突。
- 代码模块打包:代码合并、压缩,减少体积、网络请求次数。
- 代码混淆:提高代码安全性。
- 资源优化,不限于JS、CSS,支持处理各种资源,如小图优化内嵌到代码中。
在webpack中,每个文件都是模块,webpack 按照一定规则来加载、编译这些模块。
webpack 核心概念:
- entry 入口 : 从哪里开始?从一个根文件入口,如“
./src/main.js
”。 - output 出口 : 到哪里去?文件编译输出位置,如“
./dist
”。 - loader 加载器 : 对源码进行转换,不同类型模块(文件)采用不同的加载器来编译转换。
- css代码:css-loader、less-loader、sass-loader、postcss-loader ... 。
- 图片资源:url-loader、file-loader ... 。
- HTML:html-minify-loader 压缩。
- Javscript:
babel-loader
转换ES6文件到ES5,babel是webpack内置的JS编译器组件。 - ...等等。
- plugin 插件 : 处理加载器完成不了的功能,通过webpack暴露的API和生命周期钩子来执行各种处理,所以插件可以在打包的不同阶段参与。
- 打包输出文件处理:拆分chunk以控制输出的文件,如提取css到一个单独文件。
vue
中复制public
到输出目录的copy-webpack-plugin
。- 每次打包前清空
dist
目录的clean-webpack-plugin
。
3.2、构建流程
webpack的构建是一个串行过程,这个过程就是把各个插件(loader、plugin)串联起来执行。️画图图吧,大概这样子的:
① 初始化
- 读取并组装配置信息进行初始化,配置信息来源包括配置文件、
cli
参数、默认配置。 - 初始化插件、配置插件的参数。
② 编译
- 从
entry
入口文件开始(vue中入口文件默认为“./src/main.js
”),递归找到所有的依赖模块,调用相应的loader
编译处理文件内容。 - 产生chunk:chunk(/tʃʌŋk/ 块)是webpack构建过程中的块,一个chunk包括等多个模块,为某个入口文件找到的所有依赖模块。然后webpack根据配置为chunk 生成资源列表(chunk assets),最终输出到文件。
③ 输出
根据配置确定输出的路径、文件名,输出到文件系统。
3.3、安装使用
npm安装webpack
、webpack-cli
两个组件。
//1.全局环境安装webpack
npm install webpack -g
//2.进入项目目录
npm init -y //初始化npm,-y忽略询问
npm install webpack webpack-cli --save-dev //安装webpack、webpack-cli 到开发环境
webpack.config.js文件简介:
var path = require('path');
module.exports = {
//模式 开发模式打包的是未压缩文件
mode:"development",
// 入口文件,是模块构建的起点,同时每一个入口文件对应最后生成的一个 chunk。
entry: './src/main.js',
// 生成文件,是模块构建的终点,包括输出文件与输出路径。
output: {
path: path.resolve(__dirname, 'dist'),
filename: '[name].js'
},
// 这里配置了处理各模块的 loader ,包括 css 预处理 loader ,es6 编译 loader,图片处理 loader。
module: {
rules: [
{
test: /\.m?js$/,
exclude: /(node_modules|bower_components)/,
use: {
loader: 'babel-loader',
options: { presets: ['@babel/preset-env'] }
}
}
{ test: /\.css$/, use: 'css-loader' },
{ test: /\.ts$/, use: 'ts-loader' }
]},
// webpack 各插件对象,在 webpack 的事件流中执行对应的方法。
plugins: [
new webpack.HotModuleReplacementPlugin()
]
};
package.json中添加构建指令,就可以运行了:npm run build
来编译代码了。
"scripts": {
"build":"webpack"
},
04、express搭建简易服务器
express 是一个基于Node.js 的组件,用于搭建一个WEB服务器,使用非常简便、灵活,(express /ɪkˈspres/ 快速、快递)。有必要了解一下,就可以自己开发服务端API了。
express 是 Node.js 官方推荐的Web开发框架,使用广泛,除了核心http服务,还有很多功能。如静态资源服务、模板解析(可用于服务端渲染)、丰富的插件支持等。如果要创建一个完整的后端项目,可以借助express
的脚手架组件搭建一个更完整的web框架。
①、准备环境:先创建一个项目文件夹 server-express
//1、创建一个项目文件夹 server-express
//2、进入项目目录
cd ../server-express
//3、初始化npm
npm init -f
//4、安装express
npm install express -D
②、编写服务端程序:创建一个index.js
//引入express模块,注意该代码是要基于Node.js运行,需要用Node的模块写法
let express = require('express');
let path = require('path');
//创建express实例
let server = new express();
//设置静态资源访问,就可以直接访问./static 目录的静态资源了
server.use('/static',express.static(path.resolve(__dirname, './static')));
//启用json解析支持,用于解析body的json数据
server.use(express.json());
//添加监听端口
server.listen(3000, err => {
if (!err)
console.log('服务器端启动成功!地址:http://localhost:3000');
})
//配置API路由:get
server.get('/user/:userId', (req, res) => {
//req.params 获取路由动态参数,req.query获取url上的get参数,同vue-router
console.log(req.params, req.query);
//返回响应数据
res.json({ id: req.params.userId, name: 'sam', age: 30 });
})
//配置API路由:post
server.post('/user/add', (req, res) => {
//req.body 获取post数据
console.log(req.body);
//返回响应数据
res.send({ status: 'OK', message: "更新成功" });
})
③、运行:node index.js
//启动服务端
$ node index.js
服务器端启动成功!地址:http://localhost:3000
//测试
http://localhost:3000/static/img01.jpg
http://localhost:3000/user/100?type=vip
http://localhost:3000/user/add // post: {"name": "张三", "age": 40}
#参考资料
️版权申明:版权所有@安木夕,本文内容仅供学习,欢迎指正、交流,转载请注明出处!原文编辑地址-语雀
前端工程化筑基-Node/npm/babel/polyfill/webpack的更多相关文章
- 大前端工程化之写一个简单的webpack插件
今天写一个简单的webpack插件,来学习一下webpack插件 webpack插件机制可以使开发者在webpack构建过程中加入自己的行为,来针对自己项目中的一些需求做一些定制化 首先我们得知道一个 ...
- 前端工程化(二)---webpack配置
导航 前端工程化(一)---工程基础目录搭建 前端工程化(二)---webpack配置 前端工程化(三)---Vue的开发模式 前端工程化(四)---helloWord 继续上一遍的配置,本节主要记录 ...
- 07 . 前端工程化(ES6模块化和webpack打包)
模块化规范 传统开发模式主要问题 /* 1. 命名冲突 2. 文件依赖 */ 通过模块化解决上述问题 /* 模块化就是把单独的一个功能封装在一个模块(文件)中,模块之间相互隔离, 但是可以通过特定的接 ...
- 使用webpack+vue.js构建前端工程化
参考文章:https://blog.csdn.net/qq_40208605/article/details/80661572 使用webpack+vue.js构建前端工程化本篇主要介绍三块知识点: ...
- vue-cli安装以及创建一个简单的项目(一)(Node\npm\webpack简单使用)
1.关系介绍 1.简单的说 Node.js 就是运行在服务端的 JavaScript. 2.NPM是随同NodeJS一起安装的包管理工具(新版的nodejs已经集成了npm),能解决NodeJS代码部 ...
- 前端工程化 Webpack基础
前端工程化 模块化 (js模块化,css模块化,其他资源模块化) 组件化 (复用现有的UI结构.样式.行为) 规范化 (目录结构的划分.编码规范化.接口规范化.文档规范化.Git分支管理) 自动化 ( ...
- [转]基于gulp和webpack的前端工程化
本文样例代码 :https://github.com/demohi/learning-gulp 本文主要简单介绍一下基于gulp和webpack的前端工程化. 技术栈 React.js reFlux ...
- 基于webpack的前端工程化开发解决方案探索(一):动态生成HTML(转)
1.什么是工程化开发 软件工程的工程化开发概念由来已久,但对于前端开发来说,我们没有像VS或者eclipse这样量身打造的IDE,因为在大多数人眼中,前端代码无需编译,因此只要一个浏览器来运行调试就行 ...
- 前端工程化 - 剖析npm的包管理机制
转自https://juejin.im/post/5df789066fb9a0161f30580c 现如今,前端开发的同学已经离不开 npm 这个包管理工具,其优秀的包版本管理机制承载了整个繁荣发展的 ...
- 创建 Web 前端开发环境(node和npm以及git)
Web 前端开发涉及多种工具,这里将常用工具的安装和配置进行说明,提供了详细的说明,为后继的开发创建一个坚实的基础. 本文介绍的工具有:NodeJS, NPM, Bower, Git 和 Grunt. ...
随机推荐
- Pytorch及Yolov5环境配置及踩坑
Pytorch及Yolov5环境配置及踩坑 1.何为Yolov5 yolo是计算机视觉方面用来进行目标检测的一个十分出名的开源框架,我搜不到官方的对此概括性的定义,但实际上也没什么必要,更重要的是会使 ...
- Java19虚拟线程都来了,我正在写的线程代码会被淘汰掉吗?
Java19中引入了虚拟线程,虽然默认是关闭的,但是可以以Preview模式启用,这绝对是一个重大的更新,今天Java架构杂谈带大家开箱验货,看看这家伙实现了什么了不起的功能. 1 为什么需要虚拟线程 ...
- Java学习之路:流程控制
2022-10-11 10:58:41 前言 本文开始流程控制方面的学习,主要包括用户交互和流程控制语句,适合新手学习. 1 用户交互Scanner 1.1 Scanner对象 Java提供了一个可以 ...
- 在vue中_this和this的区别
_this只是一个变量名,this代表父函数,如果在子函数还用this,this的指 向就变成子函数了,_this就是用来存储指向的 普通函数中的this表示调用此函数时的对象,箭头函数里面的this ...
- DevOps|从特拉斯辞职风波到研发效能中的不靠谱人干的荒唐事
今天发生了一件大事特拉斯辞任英国首相,我想借着这件事情说下我看到的一件研发效能的荒唐事,这其中的关联也许就是「都用了不靠谱的人」. 两件事情 今儿一早就听到,2022年10月20日英国第78任首相伊丽 ...
- python: m个位置,每个位置有n种可能,求所有排列结果
>>> import itertools >>> m, n = 3, 2 >>> paths = list(itertools.product(r ...
- 30.Serializers模块源码解析
rest_framework序列化类的继承关系 field类: 序列化基类的基类 BaseSerializer: 继承field 派生ListSerializer序列化类 Serializer: 继承 ...
- 如何在Spring Boot开启事务
说到事务,那什么是事务呢? 事务(Transaction),一般是指要做的或所做的事情. 原子性(Atomicity):事务作为一个整体被执行,包含在其中的对数据库的操作要么全部被执行,要么都不执行. ...
- Python基础之模块:7、项目开发流程和项目需求分析及软件开发目录
一.项目开发流程 1.项目需求分析 明确项目具体功能: 明确到底要写什么东西,实现什么功能,在这个阶段的具体要询问项目经理和客户的需求 参与人员: 产品经理.架构师.开发经理 技术人员主要职责: 引导 ...
- Python用yield form 实现异步协程爬虫
很古老的用法了,现在大多用的aiohttp库实现,这篇记录仅仅用做个人的协程底层实现的学习. 争取用看得懂的字来描述问题. 1.什么是yield 如果还没有怎么用过的话,直接把yield看做成一种特殊 ...