位置: IT常识 - 正文

前端工程化详解——理解与实践前端工程化(前端工程化解决方案)

编辑:rootadmin
前端工程化详解——理解与实践前端工程化

推荐整理分享前端工程化详解——理解与实践前端工程化(前端工程化解决方案),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:前端工程化做了哪些东西,怎么做,前端 工程化,前端工程化做了哪些东西,怎么做,前端 工程化,前端工程化做了哪些东西,怎么做,前端工程化包含哪些,前端工程化做了哪些东西,怎么做,前端工程化做了哪些东西,怎么做,内容如对您有帮助,希望把文章链接给更多的朋友!

前言: 前端工程化一直是一个老生常谈的问题,不管是面试还是我们在公司做基建都会经常提到前端工程化,那么为什么经常会说到前端工程化,并没有听过后端工程化、Java工程化或者Python工程化呢?我们理解的前端工程化是不是一直都是Webpack的性能调优,或者是一个cli工具呢?今天我们带着问题来一起寻找一下答案吧!

文章目录一、前端工程化简介1. 前端发展历史二、工程化整体流程三、相关面试题1. 一个新项目由你来做技术选型,你会从那几个方面来考虑?2. 前端项目应该如何部署上线a. 集成b. 发布四、大厂工程化实践及开源方案五、迷你工程化脚手架实践一、前端工程化简介

我们整天再说前端工程化,那我我们思考一下,为什么会有前端工程化这个 概念?我们来一起回顾前端的发展历史,通过这个发展历史我们就能知道为什么会有【前端工程化】这个概念。

1. 前端发展历史

看下面流程图我们可以看出来 第一阶段:前端最早期的只是HTML、CSS、JS(此时只是前端发展的一个雏形,【JS】还没有模块化的概念),随着页面发展我们发现一个页面引入太多JS脚本,将大大增加维护成本; 第二阶段:已经出现了模块的概念,会按照模块的概念进行拆分,我们如何拆分模块,如何放置这些模块?此时已经有了一个工程化的概念; 第三个阶段:模块已经划分出来,但是我们部署的时候还是想合并在一起,就涉及到了早起的打包处理; 第四个阶段:前端进一步复杂之后,前端需要承载的功能更多了,逐步开始进行前后端分离,前端也可以独立的开发了。此时前端也出来了一些新的概念,比如说:SPA、Angular、Vue等。此时就要开始考虑路由如何规划?开发时如何调试?开发完如何构建?构建完如何发布?这一切的东西才构成了【前端工程化的概念】;

HTMLCSSJSAMD:异步模块加载CMD:同步模块加载Commonjs:09年Node.jsES-Model:15年ES6的出现Gruntgulpjade前后端分离

综上所述我们可以看出来,前端工程化绝不只是webpack或babel构建这一块,前端工程化是一个整体,从前端开始写代码 --> 如何构建 --> 如何发布测试 --> 如何上线 --> 上线后的应用状态如何监控等,这一套的流程我们把他叫做【前端工程化】。

二、工程化整体流程**下图所示,就是我们从零开始整个前端工程化的考虑范围**1. 从创建项目与开发阶段--> 我们要使用脚手架,对应的Eslint规范以及我们要使用什么UI组件库2. CI --> 持续集成: 在一个集中的环境去构建我们的项目(避免不同协作人员环境不同带来的Bug)3. CD --> 持续部署下面面试题 【前端项目应该如何部署上线】 会对 CI/CD做详细的介绍创建项目开发构建测试上线脚手架规范 + Eslint组件库CI:持续构建CD:持续部署监控

为什么开篇说到后端没有工程化的概念? 我们比如Java语言,他天生就是一种企业级的开发语言,他已经把上述流程包括在里面,不需要自己在去做这些基础建设;而JS是一门脚本语言,在不断开发不断迭代的进展中演变出了前端工程化的这个概念。

三、相关面试题1. 一个新项目由你来做技术选型,你会从那几个方面来考虑?前端工程化详解——理解与实践前端工程化(前端工程化解决方案)

第二个大话题,【工程化整体流程 】都是我们需要考虑的

2. 前端项目应该如何部署上线老规矩,先看图,下图是正常的前端发布流程

下面的流程大家觉得有什么问题吗? 很多公司都是这样的一个流程,我们要知道服务器是做什么的?服务器应该是运行一些动态的程序,比如我们的Java代码,NodeJs代码,他是动态去处理数据,处理我们客户端的请求的。但是我们打包构建好的JS是一个文件,我们把一个静态文件放置一台服务器是不是就会很浪费成本,所以下图的流程一般是后端的部署流程

开发代码git push--触发webHook集成Jenkins:Docker构建代码发布服务器Nginx

前端部署一般会加上CDN(内容分发网络) 为什么要加CDN,第一优化加载速度(网络时延导致的速度过慢),第二把不需要动态处理的文件(JS/CSS/Image/Video)放在CDN节省服务器资源。

最后两个步骤,主要是快速回滚,假如我们发布到线上的代码出现了问题,再重头集成,大概需要十分钟,而这十分钟客户一直看到的是有问题的页面! 每次 HTML 加载的时候我们会先去读取版本,然后拿到对应版本的JS/CSS,这样的话所有的CSS和JS都是有对应版本的,一旦发现问题直接通过HTML 加载上一次的版本即可。

开发代码git push--触发webHook集成Jenkins:Docker构建代码HTMLJS + CSS =>CDNVersiona. 集成

这里详细解释一下为什么要在集成的环境(也叫云构建)去进行 npm run build ? 为什么不在本地环境进行构建,要在集成的环境构建,这里核心的问题就是,没有办法保证每个人的环境(比如:npm版本、node版本)是一样的,假设不环境不一样的话,构建出来的产物就会有差异,发布上线以后出现问题很难排查。

b. 发布

前端的代码应该是运行在哪里? 运行在一台物理服务器或者云服务器上

四、大厂工程化实践及开源方案

蚂蚁金服开源的 UmiJS; 它提前预定好很多功能,我们可以做到开箱即用,其实 UmiJS 已经是前端工程化一个很好的范例与实践(包含基础配置比如路由、mock、构建(Webpack)、部署)。

阿里开源的 飞冰 它和 UmiJS 一样也是基于React去设计的,飞冰比 UmiJS 内置的功能要更多一点,比如:数据请求、状态管理、日志打印、菜单配置等等。

字节跳动开源的 MODERN.js MODERN 会比飞冰与UmiJS包含的内容更多一些,它是按照业务场景把功能做了一个更细致的分类,比如:正常网站、中后台、桌面应用、微前端等等,主要的是支持Vue。

五、迷你工程化脚手架实践时间有限稍后给大家补上,抱歉抱歉!!!
本文链接地址:https://www.jiuchutong.com/zhishi/300249.html 转载请保留说明!

上一篇:共享主机和 WordPress 主机之间的区别(共享主机和vps)

下一篇:【OpenCV】Qt + OpenCV 开发配置 + 入门知识(代码示例)(qt opencv ffmpeg)

  • 怎么修改金税盘登录密码
  • 转让无形资产可以免税吗
  • 土地取得方式有哪些
  • 企业所得税减免优惠政策
  • 财务负责人如何解绑
  • 外购商品发放给员工 进项税额能不能抵扣
  • 公司法人必须办社保吗?
  • 银行对账单由谁去取
  • 摄影服务的开票项目
  • 金蝶未结账是否可以重新起账
  • 视同销售的销售额如何确定
  • 增值税采用零税率政策的内容
  • 企业设备融资是什么意思?
  • 企业购买扶贫物资怎么入账
  • 意外险部分费用怎么算
  • 税控盘服务费跨年还能抵吗
  • 停车费专用发票可以抵扣进项税吗
  • 7.1增值税普通发票怎么开?
  • 个体户超过3万怎么纳税
  • 工程备用金金额怎么算
  • 金融企业准备金计提管理办法最新
  • 融资租赁与经营租赁的相同点
  • 货款打多了对方不愿意退款
  • 个人独资企业的特点
  • 长期股权投资减值的判断依据
  • 退休人员再就业受伤算工伤吗
  • 合同印花税交给谁
  • 如何查看电脑是什么牌子
  • 其他货币资金包括哪些内容
  • pdv文件什么意思
  • mcappins.exe - mcappins进程是什么文件 什么意思.
  • phpipam使用
  • 坏账减值准备账务处理
  • 成本法的优点是计算较为简便,缺点是
  • 离职赔偿金计入什么费用
  • 实缴资本多久可以取出随便用吗
  • 小企业如何记账
  • vue写的购物车详细步骤
  • 公司给员工发放福利会计分录
  • 商贸公司用什么名字最好
  • 财政科技支出
  • java中map.entry
  • 土地评估增值计入什么科目
  • 技术开发费免税政策
  • mysql数据库在使用时的常见错误号和解决方法有哪些?
  • 收据和发票有什么用
  • 纳税滞纳金的计算方法
  • 发票入账抵扣什么意思
  • 外地工程预缴的工资怎么做账务处理
  • 税盘减免税款怎么做账
  • 装修费用摊销计入什么科目
  • 企业购买土地如何缴税
  • 生鲜配送账务处罚标准
  • 电子承兑非拒付会怎么样
  • 设立明细账的目的
  • 总帐设置在哪
  • sql server启动不了 错误2
  • mysql解压安装教程5.7
  • centos7阿里云yum源
  • kms激活的弊端
  • win8官方u盘安装教程
  • u启动开机启动快捷键
  • java操作windows的文件管理器
  • 快速锁定单元格的方法
  • windows 8升级
  • win7系统宽带连接651
  • windows 8连接vpn设置方法(消费者预览版)
  • 使用速度最快的手机
  • 鼠标焦点离开触发查询
  • linux查看so中的函数
  • 动作手游排行榜2020前十名
  • 用javascript
  • 全面解析A型天秤座男
  • 安卓手机管家删除的照片怎么恢复
  • amd模拟intel
  • 新疆省国税局
  • 内蒙古自治区耕地保养条例
  • 河北耕地占用税最新规定
  • 广西怎么查社保记录
  • 体育局和什么局合并了
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设