达内广州C++学院|c++培训|广州达内科技C++/C#培训|.NET培训|IT培训|达内广州岗顶中心 达内广州C++学院|c++培训|广州达内科技C++/C#培训|.NET培训|IT培训|达内广州岗顶中心
软件测试工程师
 当前位置:主页 > 高端课程 > 软件测试工程师 >

025.前端工程构建

时间:2019-06-17  来源:未知  作者:广州达内培训

一、前端工程构建过程

  • 前端开发框架:vue、react、Angular 等;
  • 前端工程构建工具:webpack、Npm Script、gulp、grunt等;
  • Js包管理工具:npm(Node Package Manager)

    npm是随同NodeJS一起安装的包管理工具(管理js代码,类似java jar包管理工具maven)

      允许用户从NPM服务器下载别人编写的第三方包到本地使用。

      允许用户从NPM服务器下载并安装别人编写的命令行程序到本地使用。

      允许用户将自己编写的包或命令行程序上传到NPM服务器供别人使用

 

1.为什么需要构建:使用框架开发的源代码无法直接在服务器运行,必须通过转换后(构建)才可以正常运行。

 

2.构建过程:将源代码转换成可执行的JavaScript、CSS、HTML代码;

  • 代码转换:将TypeScript编译成JavaScript、将SCSS编译成CSS等。
  • 文件优化:压缩JavaScript、CSS、HTML代码,压缩合并图片等。
  • 代码分割:提取多个页面的公共代码,提取首屏不需要执行部分的代码让其异步加载。
  • 模块合并:在采用模块化的项目里会有很多个模块和文件,需要通过构建功能将模块分类合并成一个文件。
  • 自动刷新:监听本地源代码的变化,自动重新构建、刷新浏览器。
  • 代码校验:在代码被提交到仓库前需要校验代码是否符合规范,以及单元测试是否通过。
  • 自动发布:更新代码后,自动构建出线上发布代码(/dist)并传输给发布系统(npm库)。

 

https://blog.csdn.net/broadview2006/article/details/79091719

https://www.sohu.com/a/234032018_231218

 

二、webpack核心概念

1.Webpack专注于构建模块化项目。

2.在Webpack里一切文件(JavaScript、CSS、SCSS、图片、模板等)皆模块,通过Loader转换文件,通过Plugin注入钩子,最后输出由多个模块组合成的文件。

  • 入口起点(Entry Points):项目提供一个入口文件,通过这个入口文件执行模块化。
  • 输出(Output):chunk多个文件组成的一个代码块,例如把一个可执行模块和它所有依赖的模块组合和一个 chunk 这体现了webpack的打包机制。
  • 加载器(Loaders):loader 是对应用程序中资源文件进行转换。它们是(运行在 Node.js 中的)函数,可以将资源文件作为参数的来源,然后返回新的资源文件。例如把es6转换为es5,scss转换为css。
  • 插件(Plugins):插件是 wepback 的支柱功能。在你使用 webpack 配置时,webpack 自身也构建于同样的插件系统上!插件目的在于解决 loader 无法实现的其他事。

 

图1.webpack构建过程

 

 

三、使用webpack构建前端工程

https://segmentfault.com/a/1190000012789253?utm_source=tag-newest

1.安装nodejs

2.新建项目目录 mkdir webpack-demo && cd webpack-demo/

3.初始化项目 (npm解决依赖关系,类似maven项目)

npm init 

 

4.安装webpack webpack-dev-server  webpack-cli  vue (使用npm安装)

npm install webpack webpack-dev-server --save-dev
npm install webpack-cli --save-dev
npm install vue --save-dev

 

 

5.编写前端代码

TODO

 

6.在package.json文件中 scripts 配置 使用webpack构建、运行的脚本

"scripts": {
    "dev": "cross-env NODE_ENV=development webpack-dev-server --open --hot",
    "build": "cross-env NODE_ENV=production webpack --progress --hide-modules"
}

 

7.构建、运行

npm run build
npm run dev

 

8.发布到npm

npm login

npm publish

 

 

https://blog.csdn.net/qq_33599109/article/details/79892975

https://blog.csdn.net/guyue_01/article/details/86526281

https://www.jianshu.com/p/71631adeedf8

 




上一篇:关于代码效率提升的方法心路历程(购物车)
下一篇:铁大FaceBook的使用体验

友情链接:
  • 全球最大晶圆代工半导体制造厂,台积电斥资订购艾斯摩尔机器设备
  • 英特尔依然是那个英特尔,且看英特尔的城防体系
  • 支持双 DRAM 内存接口,慧荣企业级 SSD 主控方案披露
  • 在全球被反垄断罚款,冤!高通到底哪里得罪了欧盟?
  • 强强联合!万业、微电子所和芯鑫共同打造全新半导体设备
  • 复旦大学校长称:对于集成电路产业发展,大学应该主动担当
  • 技术再升级!无锡中科芯攻克晶圆级再布线及晶圆级凸点制备关键技
  • 聚力!万业企业设立集成电路装备集团,提供自主可控设备
  • 德州仪器C2000微控制器增强连通性和控制性
  • 英特尔打出降价策略,以免被竞争对手 AMD 打败?
  • 贸易摩擦的闹剧没有赢家,苹果有勇气离开中国吗?
  • 图像信号与视觉处理器的发展趋势
  • 真干快消品定位方案班(第二期)火热开班
  • Java集合 ArrayList原理及使用
  • TDD(测试驱动开发)死了吗?
  • JAVA基础之XML相关
  • javaweb项目搭建ehcache缓存系统
  • 每日一码——字符串统计
  • 一篇文章帮你彻底搞清楚“I/O多路复用”和“异步I/O”的前世今生
  • 九:模板方法模式
  • 十二:命令模式(人员解耦和)
  • Java 转PPT为图片、PDF、SVG、XPS、ODP以及PPT和PPTX互转
  • SpringCloud学习(SPRINGCLOUD微服务实战)一
  • 记一次微信网页授权后获取用户信息并重定向
  • 速途新营销五点实战洞察解码“品效合一”
  • 十一:外观模式详解(Service,action与dao)
  • 手把手教你学会 基于JWT的单点登录
  • mysql锁机制总结,以及优化建议
  • 解决多个版本jar包冲突【jar内包名重命名】
  • 中国首张5G终端电信设备进网许可证 华为Mate 20 X 5G版入网
  • RPC之Thrift
  • 高级Java工程师必备 ----
  • 天猫618期间实物支付GMV增长38.5%
  • 换季了,老板你的库存处理好了吗?
  • 从“618”大数据看中国消费新活力
  • 小米生态链:贵在格局感与收放度
  • CODING 2.0 企业级持续交付解决方案
  • 老铁奇趴“新京济” 快手*京东618战报出炉
  • 中小企业新媒体运营基本技能
  • 上汽大通房车再度携手LINE FRIENDS 魔都巡游顺利开启
  • 华为高端手机国内市场份额超苹果夺得榜首
  • 中国智能制造分析报告
  • iPlus艾加营销助力腾讯广告牵手吴晓波 推进商业IP变现
  • 2019世界新能源汽车大会7月1日将在海南举行
  • 区域酒企如何转型突围
  • 时时彩论坛
  • 五星体育斯诺克
  • 北单比分直播
  • 河北11选5走势图
  • 福建体彩36选7开奖结果
  • 九龙图库下载